ThinkPHP模板引擎之導(dǎo)入資源文件方法詳解
一般而言,網(wǎng)頁傳統(tǒng)方式的導(dǎo)入外部JS和CSS等資源文件的方法是直接在模板文件使用:
<script type='text/javascript' src='/Public/Js/Util/Array.js'> <link rel="stylesheet" type="text/css" href="/App/Tpl/default/Public/css/style.css" />
ThinkPHP的模板引擎提供了專門的標(biāo)簽來簡化上面的導(dǎo)入。
1.import標(biāo)簽
第一個(gè)是import標(biāo)簽 ,導(dǎo)入方式采用類似ThinkPHP的import函數(shù)的命名空間方式,例如:
<import type='js' file="Js.Util.Array" />
Type屬性默認(rèn)是js, 所以下面的效果是相同的:
<import file="Js.Util.Array" />
還可以支持多個(gè)文件批量導(dǎo)入,例如:
<import file="Js.Util.Array,Js.Util.Date" />
導(dǎo)入外部CSS文件必須指定type屬性的值,例如:
<import type='css' file="Css.common" />
上面的方式默認(rèn)的import的起始路徑是網(wǎng)站根目錄下的Public目錄,如果需要指定其他的目錄,可以使用basepath屬性,例如:
<import file="Js.Util.Array" basepath="./Common" />
如果導(dǎo)入的文件中含有“.”號,則可以采用:
<import file="Js.Util.Array#min" />
表示導(dǎo)入 /Public/Js/Util/Array.min.js 資源文件。
還支持資源文件的版本號導(dǎo)入,例如:
<import type='js' file="Js.Util.Array?v=120" />
在導(dǎo)入多個(gè)文件的時(shí)候也可以支持
<import type='js' file="Js.Util.Array?125,Js.Util.Date?130" />
improt標(biāo)簽支持判斷加載,例如下面首先判斷name變量是否設(shè)置:
<import type='js' file="Js.Util.Array" value="name" />
或者更復(fù)雜的,甚至可以采用函數(shù):
<import type='js' file="Js.Util.Array" value="Think.get.name|isset" />
編譯后的模板緩存是:
<?php if(isset($_GET['name'])): ?> <script type="text/javascript" src="/Public/Js/Util/Array.js"></script> <?php endif; ?>
2.load標(biāo)簽
第二個(gè)是load標(biāo)簽,通過URL方式導(dǎo)入當(dāng)前項(xiàng)目的公共JS或者CSS,例如:
<load href="/Public/Js/Common.js" /> <load href="/Public/Js/Date.js?v=235" /> <load href="/Public/Css/common.css" />
在href屬性中可以使用特殊模板標(biāo)簽替換,例如:
<load href="!-PUBLIC-!/Js/Common.js" />
Load標(biāo)簽無需指定type屬性,系統(tǒng)會(huì)自動(dòng)根據(jù)后綴自動(dòng)判斷。
當(dāng)然,load標(biāo)簽也支持條件判斷調(diào)用:
<load href="/Public/Js/Common.js" value="name" />
系統(tǒng)還提供了兩個(gè)標(biāo)簽別名js和css 用法和load一致,例如:
<js href="/Public/Js/Common.js" /> <css href="/Public/Css/common.css" />
load標(biāo)簽也支持同時(shí)導(dǎo)入多個(gè)資源文件,甚至是不同類型的資源文件:
<load href="/Public/Js/Common.js,/Public/Css/common.css" />
相關(guān)文章
laravel 解決paginate查詢多個(gè)字段報(bào)錯(cuò)的問題
今天小編就為大家分享一篇laravel 解決paginate查詢多個(gè)字段報(bào)錯(cuò)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10laravel 出現(xiàn)command not found問題的解決方案
今天小編就為大家分享一篇laravel 出現(xiàn)command not found問題的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10PHP isset empty函數(shù)相關(guān)面試題及解析
這篇文章主要介紹了PHP isset empty函數(shù)相關(guān)面試題及解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12php將url地址轉(zhuǎn)化為完整的a標(biāo)簽鏈接代碼(php為url地址添加a標(biāo)簽)
這篇文章主要介紹了php為url地址添加a標(biāo)簽的示例,大家參考使用吧2014-01-01php curl模擬post請求和提交多維數(shù)組的示例代碼
這篇文章主要介紹了php curl模擬post請求和提交多維數(shù)組的示例代碼,需要的朋友可以參考下2015-11-11