• 技术文章 >后端开发 >php教程

    分享ThinkPHP模板引擎导入资源文件的方案

    不言不言2018-06-19 15:49:19原创537
    这篇文章主要介绍了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中文网!

    相关推荐:

    关于thinkPHP5框架自定义验证器的实现方法

    对于Laravel框架模板加载和分配变量及简单路由的功能

    以上就是分享ThinkPHP模板引擎导入资源文件的方案的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    上一篇:关于PHP实现微信红包金额拆分的算法 下一篇:如何利用php判断输入不超过mysql的varchar字段的长度范围
    大前端线上培训班

    相关文章推荐

    • 推荐一本PHP程序猿都应该拜读的书_PHP• Thinkphp关闭缓存的方法_php实例• php实现图片添加水印功能_php实例• PHP命名空间(Namespace)的使用详解_php实例• 请问一个PHP安装程序的小疑点

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网