|
一般而言,網(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" />
編譯后的模板緩存是:
<?phpif(isset($_GET['name'])): ?><script type="text/Javascript" src="/Public/Js/Util/Array.js"></script><?phpendif;?>
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" />
php技術(shù):ThinkPHP模板引擎之導(dǎo)入資源文件方法詳解,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。