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