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

 更新时间:2014年06月18日 18:09:52   投稿:shichen2014  
这篇文章主要介绍了ThinkPHP模板引擎的导入资源文件方法,需要的朋友可以参考下

一般而言,网页传统方式的导入外部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检查函数必传参数是否存在的实例详解

    这篇文章主要介绍了php检查函数必传参数是否存在的实例详解的相关资料,需要的朋友可以参考下
    2017-08-08
  • 百度地图API应用之获取用户的具体位置

    百度地图API应用之获取用户的具体位置

    以前一直用高德地图的API,后来因为需求,必须用百度的地图API。这些API都已经封装的很智能了,只需要一定的编程思维,就很简单可以实现功能。
    2014-06-06
  • php笔记之:php函数range() round()和list()的使用说明

    php笔记之:php函数range() round()和list()的使用说明

    本篇文章介绍了,php函数range() round()和list()的使用说明。需要的朋友参考下
    2013-04-04
  • Yii控制器中filter过滤器用法分析

    Yii控制器中filter过滤器用法分析

    这篇文章主要介绍了Yii控制器中filter过滤器用法,结合实例形式简单分析了过滤器filter的使用步骤与功能实现技巧,需要的朋友可以参考下
    2016-07-07
  • Laravel事件系统实现浏览量的统计

    Laravel事件系统实现浏览量的统计

    Laravel的事件系统提供了一种简单而强大的方式来实现浏览量的统计,通过创建浏览事件和事件监听器,以及在合适的地方触发事件,我们可以轻松地实现网页浏览量的统计功能,本文将介绍如何使用Laravel的事件系统来实现浏览量的统计
    2024-03-03
  • php 实现银联商务H5支付的示例代码

    php 实现银联商务H5支付的示例代码

    这篇文章主要介绍了php 实现银联商务H5支付的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • PHP实现简单计算器小程序

    PHP实现简单计算器小程序

    这篇文章主要为大家详细介绍了PHP实现简单计算器小程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • destoon实现调用图文新闻的方法

    destoon实现调用图文新闻的方法

    这篇文章主要介绍了destoon实现调用图文新闻的方法,是非常实用的技巧,需要的朋友可以参考下
    2014-08-08
  • Yii框架用户登录session丢失问题解决方法

    Yii框架用户登录session丢失问题解决方法

    这篇文章主要介绍了Yii框架用户登录session丢失问题解决方法,通过针对底层代码的修改解决session丢失问题,具有一定参考借鉴价值,需要的朋友可以参考下
    2017-01-01
  • laravel下trait的使用代码实例详解

    laravel下trait的使用代码实例详解

    这篇文章主要介绍了laravel下trait的使用代码实例详解,使用trait可以提高代码的复用性,有感兴趣的同学可以学习下
    2021-03-03

最新评论