>[info] `ThinkTemplate`是一个基于XML的性能卓越的编译型模板引擎,支持两种类型的模板标签,使用了动态编译和缓存技术,而且支持自定义标签库,一直作为`ThinkPHP`的内置模板引擎,现已经支持独立使用。
## 主要特性:
* 支持模板标签定界符定义;
* 支持直接使用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>
~~~