本章的内容主要讲述了如何使用内置的模板引擎。

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>