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 相关文章推荐
用php来检测proxy
Oct 09 PHP
将时间以距今多久的形式表示,PHP,js双版本
Sep 25 PHP
php函数间的参数传递(值传递/引用传递)
Sep 23 PHP
php提示Warning:mysql_fetch_array() expects的解决方法
Dec 16 PHP
PHP使用Pthread实现的多线程操作实例
Nov 14 PHP
mac系统下为 php 添加 pcntl 扩展
Aug 28 PHP
PHP 搜索查询功能实现
Nov 29 PHP
总结PHP代码规范、流程规范、git规范
Jun 18 PHP
PHP PDOStatement::setAttribute讲解
Feb 01 PHP
关于Yii中模型场景的一些简单介绍
Sep 22 PHP
Laravel监听数据库访问,打印SQL的例子
Oct 24 PHP
PHP命令行与定时任务
Apr 01 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
php自定义函数call_user_func和call_user_func_array详解
2011/07/14 PHP
thinkphp中AJAX返回ajaxReturn()方法分析
2016/12/06 PHP
Laravel 修改验证异常的响应格式实例代码详解
2020/05/25 PHP
jquery 图片 上一张 下一张 链接效果(续篇)
2010/04/20 Javascript
jquery ajax跨域解决方法(json方式)
2014/02/04 Javascript
jQuery中innerHeight()方法用法实例
2015/01/19 Javascript
window.setInterval()方法的定义和用法及offsetLeft与style.left的区别
2015/11/11 Javascript
JavaScript高级程序设计(第三版)学习笔记6、7章
2016/03/11 Javascript
Javascript学习之谈谈JS的全局变量跟局部变量(推荐)
2016/08/28 Javascript
快速实现jQuery多级菜单效果
2017/02/01 Javascript
js+canvas实现动态吃豆人效果
2017/03/22 Javascript
详解Angular.js数据绑定时自动转义html标签及内容
2017/03/30 Javascript
php简单数据库操作类的封装
2017/06/08 Javascript
js排序与重组的实例讲解
2017/08/28 Javascript
AngularJS遍历获取数组元素的方法示例
2017/11/11 Javascript
vue中利用Promise封装jsonp并调取数据
2019/06/18 Javascript
vue微信分享插件使用方法详解
2020/02/18 Javascript
JavaScript实现简单的弹窗效果
2020/05/19 Javascript
[57:53]DOTA2上海特级锦标赛主赛事日 - 2 败者组第二轮#3OG VS VP
2016/03/03 DOTA
Python实现删除文件但保留指定文件
2015/06/21 Python
python验证码识别实例代码
2018/02/03 Python
django 开发忘记密码通过邮箱找回功能示例
2018/04/17 Python
Django中URL的参数传递的实现
2019/08/04 Python
使用tensorflow DataSet实现高效加载变长文本输入
2020/01/20 Python
python2 对excel表格操作完整示例
2020/02/23 Python
html5中监听canvas内部元素点击事件的三种方法
2019/04/28 HTML / CSS
荷兰睡眠专家:Beter Bed
2020/11/23 全球购物
如何用Java实现列出某个目录下的所有子目录
2015/07/20 面试题
电气工程师岗位职责
2014/01/01 职场文书
工程安全员岗位职责
2014/03/09 职场文书
法人授权委托书
2014/04/03 职场文书
作文评语大全
2014/04/23 职场文书
2015年部门工作总结范文
2015/03/31 职场文书
Redis遍历所有key的两个命令(KEYS 和 SCAN)
2021/04/12 Redis
JavaScript控制台的更多功能
2021/04/28 Javascript
Java elasticsearch安装以及部署教程
2021/06/28 Java/Android