ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
本章的内容主要讲述了如何使用内置的模板引擎。 >[info] ThinkPHP内置了一个基于XML的性能卓越的模板引擎,这是一个专门为ThinkPHP服务的内置模板引擎,使用了XML标签库技术的编译型模板引擎,支持两种类型的模板标签,使用了动态编译和缓存技术,而且支持自定义标签库。 其特点包括: - 支持XML标签库和普通标签的混合定义; - 支持直接使用PHP代码书写; - 支持文件包含; - 支持多级标签嵌套; - 支持布局模板功能; - 一次编译多次运行,编译和运行效率非常高; - 模板文件和布局模板更新,自动更新模板缓存; - 系统变量无需赋值直接输出; - 支持多维数组的快速输出; - 支持模板变量的默认值; - 支持页面代码去除Html空白; - 支持变量组合调节器和格式化功能; - 允许定义模板禁用函数和禁用PHP语法; - 通过标签库方式扩展。 每个模板文件在执行过程中都会生成一个编译后的缓存文件,其实就是一个可以运行的PHP文件。 >[info] 由于编译型模板引擎的特性,模板缓存不能关闭,就算关闭缓存也会在每次渲染的时候重新生成模板缓存。 内置的模板引擎支持普通标签和XML标签方式两种标签定义,分别用于不同的目的: | 标签类型 | 描述 | |-----|-----| | 普通标签 | 主要用于输出变量、函数过滤和做一些基本的运算操作 | | XML标签 | 也称为标签库标签,主要完成一些逻辑判断、控制和循环输出,并且可扩展 | 这种方式的结合保证了模板引擎的简洁和强大的有效融合。 模板文件可以同时包含普通标签和标签库标签,标签的定界符都可以重新配置。 ## 普通标签 普通标签用于变量输出和模板注释,普通模板标签默认以`{` 和 `}` 作为开始和结束标识,并且在开始标记紧跟标签的定义,如果之间有空格或者换行则被视为非模板标签直接输出。 例如:`{$name}` 、`{$vo.name}` 、`{$vo['name']|strtoupper}` 都属于正确的标签,而`{ $name}` 、`{ $vo.name}`则不属于。 要更改普通标签的起始标签和结束标签,可以更改`template.php`中的配置参数: ~~~ // 普通标签开始标记 'tpl_begin' => '<{', // 普通标签结束标记 'tpl_end' => '}>' ~~~ 普通标签的定界符就被修改了,原来的 `{$name}` 和 `{$vo.name}` 必须使用 `<{$name}>` 和 `<{$vo.name}>` 才能生效了。 >[danger] 本手册后面的内容均使用默认的标签定界符配置进行说明 ## 标签库标签 标签库标签可以用于模板变量输出、文件包含、条件控制、循环输出等功能,而且完全可以自己扩展功能。 5.1版本的标签库默认定界符和普通标签一样使用`{`和`}`,是为了便于在编辑器里面编辑不至于报错,当然,你仍然可以更改标签库标签的起始和结束标签,修改下面的配置参数: ~~~ //标签库标签开始标签 'taglib_begin' => '<', //标签库标签结束标记 'taglib_end' => '>', ~~~ 原来的 ~~~html {eq name="name" value="value"} 相等 {else/} 不相等 {/eq} ~~~ 就需要改成 ~~~html <eq name="name" value="value"> 相等 <else/> 不相等 </eq> ~~~