ThinkPHP模板引擎之导入资源文件方法详解


Posted in PHP onJune 18, 2014

一般而言,网页传统方式的导入外部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的模板引擎提供了专门的标签来简化上面的导入。

1.import标签

第一个是import标签 ,导入方式采用类似ThinkPHP的import函数的命名空间方式,例如:

<import type='js' file="Js.Util.Array" />

Type属性默认是js, 所以下面的效果是相同的:

<import file="Js.Util.Array" />

还可以支持多个文件批量导入,例如:

<import file="Js.Util.Array,Js.Util.Date" />

导入外部CSS文件必须指定type属性的值,例如:

<import type='css' file="Css.common" />

上面的方式默认的import的起始路径是网站根目录下的Public目录,如果需要指定其他的目录,可以使用basepath属性,例如:

<import file="Js.Util.Array" basepath="./Common" />

如果导入的文件中含有“.”号,则可以采用:

<import file="Js.Util.Array#min" />

表示导入 /Public/Js/Util/Array.min.js 资源文件。

还支持资源文件的版本号导入,例如:

<import type='js' file="Js.Util.Array?v=120" />

在导入多个文件的时候也可以支持

<import type='js' file="Js.Util.Array?125,Js.Util.Date?130" />

improt标签支持判断加载,例如下面首先判断name变量是否设置:

<import type='js' file="Js.Util.Array" value="name" />

或者更复杂的,甚至可以采用函数

<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标签

第二个是load标签,通过URL方式导入当前项目的公共JS或者CSS,例如:

<load href="/Public/Js/Common.js" />
<load href="/Public/Js/Date.js?v=235" />
<load href="/Public/Css/common.css" />

在href属性中可以使用特殊模板标签替换,例如:

<load href="!-PUBLIC-!/Js/Common.js" />

Load标签无需指定type属性,系统会自动根据后缀自动判断。
当然,load标签也支持条件判断调用:

<load href="/Public/Js/Common.js" value="name" />

系统还提供了两个标签别名js和css 用法和load一致,例如:

<js href="/Public/Js/Common.js" />
<css href="/Public/Css/common.css" />

load标签也支持同时导入多个资源文件,甚至是不同类型的资源文件

<load href="/Public/Js/Common.js,/Public/Css/common.css" />
PHP 相关文章推荐
VML绘图板②脚本--VMLgraph.js、XMLtool.js
Oct 09 PHP
PHP+APACHE实现用户论证的方法
Oct 09 PHP
PHP 应用程序的安全 -- 不能违反的四条安全规则
Nov 26 PHP
php empty() 检查一个变量是否为空
Nov 10 PHP
php制作简单模版引擎
Apr 07 PHP
php错误日志简单配置方法
Jul 11 PHP
浅谈php数组array_change_key_case() 函数和array_chunk()函数
Oct 22 PHP
php中get_magic_quotes_gpc()函数说明
Feb 06 PHP
轻松实现php文件上传功能
Feb 17 PHP
php使用curl实现ftp文件下载功能
May 16 PHP
php简单读取.vcf格式文件的方法示例
Sep 02 PHP
搭建PhpStorm+PhpStudy开发环境的超详细教程
Sep 17 PHP
ThinkPHP CURD方法之field方法详解
Jun 18 #PHP
ThinkPHP CURD方法之data方法详解
Jun 18 #PHP
ThinkPHP CURD方法之order方法详解
Jun 18 #PHP
ThinkPHP CURD方法之table方法详解
Jun 18 #PHP
ThinkPHP CURD方法之page方法详解
Jun 18 #PHP
ThinkPHP CURD方法之limit方法详解
Jun 18 #PHP
ThinkPHP CURD方法之where方法详解
Jun 18 #PHP
You might like
linux下编译安装memcached服务
2014/08/03 PHP
PHP实现网站应用微信登录功能详解
2019/04/11 PHP
jQuery ajax BUG:object doesn't support this property or method
2010/07/06 Javascript
javascript游戏开发之《三国志曹操传》零部件开发(一)让静态人物动起来
2013/01/23 Javascript
JQuery对class属性的操作实现按钮开关效果
2013/10/11 Javascript
详细解密jsonp跨域请求
2015/04/15 Javascript
jQuery实现企业网站横幅焦点图切换功能实例
2015/04/30 Javascript
jQuery模拟物体自由落体运动(附演示与demo源码下载)
2016/01/21 Javascript
JS禁止查看网页源代码的实现方法
2016/10/12 Javascript
最细致的vue.js基础语法 值得收藏!
2016/11/03 Javascript
JS批量替换内容中关键词为超链接
2017/02/20 Javascript
利用Vue.js框架实现火车票查询系统(附源码)
2017/02/27 Javascript
微信网页登录逻辑与实现方法
2019/04/29 Javascript
了解JavaScript函数中的默认参数
2019/05/30 Javascript
antd中table展开行默认展示,且不需要前边的加号操作
2020/11/02 Javascript
原生JS实现拖拽效果
2020/12/04 Javascript
使用setup.py安装python包和卸载python包的方法
2013/11/27 Python
python3 与python2 异常处理的区别与联系
2016/06/19 Python
python中的随机函数random的用法示例
2018/01/27 Python
实时获取Python的print输出流方法
2019/01/07 Python
Python I/O与进程的详细讲解
2019/03/08 Python
利用python实现逐步回归
2020/02/24 Python
Python socket连接中的粘包、精确传输问题实例分析
2020/03/24 Python
django正续或者倒序查库实例
2020/05/19 Python
AVON雅芳官网:世界上最大的美容化妆品公司之一
2016/11/02 全球购物
美国在线宠物用品商店:Entirely Pets
2017/01/01 全球购物
STAUD官方网站:洛杉矶独有的闲适风格
2019/04/11 全球购物
BIFFI美国站:意大利BIFFI BOUTIQUES豪华多品牌时装零售公司
2020/02/11 全球购物
阿迪达斯中国官网:Adidas中国
2020/12/14 全球购物
什么是makefile? 如何编写makefile?
2013/01/02 面试题
公司司机岗位职责
2014/02/07 职场文书
信息专业学生学习的自我评价
2014/02/17 职场文书
英语教师自荐信
2014/05/26 职场文书
爱心捐书活动总结
2014/07/05 职场文书
家装电话营销开场白
2015/05/29 职场文书
红白喜事主持词
2015/07/06 职场文书