标签扩展
最后更新于:2022-04-02 07:25:44
## 标签扩展
>[info]建议开发者将自定义标签库请放置应用目录中,请勿放在框架系统目录内,以免使用`Composer`更新框架时导致自定义标签库的丢失
下面是一个Demo标签库的示例:
~~~
['attr' => 'time,format', 'close' => 0], //闭合标签,默认为不闭合
'open' => ['attr' => 'name,type', 'close' => 1],
];
/**
* 这是一个闭合标签的简单演示
*/
public function tagClose($tag)
{
$format = empty($tag['format']) ? 'Y-m-d H:i:s' : $tag['format'];
$time = empty($tag['time']) ? time() : $tag['time'];
$parse = '';
return $parse;
}
/**
* 这是一个非闭合标签的简单演示
*/
public function tagOpen($tag, $content)
{
$type = empty($tag['type']) ? 0 : 1; // 这个type目的是为了区分类型,一般来源是数据库
$name = $tag['name']; // name是必填项,这里不做判断了
$parse = '';
$parse .= '{volist name="__LIST__" id="' . $name . '"}';
$parse .= $content;
$parse .= '{/volist}';
return $parse;
}
}
~~~
这时候我们的控制器继承`Controller`,在配置参数中配置:
~~~
'template' => [
// 模板引擎类型 支持 php think 支持扩展
'type' => 'Think',
// 模板路径
'view_path' => '',
// 模板后缀
'view_suffix' => '.html',
// 预先加载的标签库
'taglib_pre_load' => 'app\common\taglib\Demo',
],
~~~
我们就可以在控制器中对模版赋值:
~~~
$this->assign('demo_time',time());
~~~
在模版中调用我们已经预先加载的标签:
~~~
{/demo:close}
{demo:close name='demo_name' type='1'} {$key}=>{$demo_name}
{/demo:close} ~~~
';
开放标签
{demo:open time='$demo_time'/}闭合标签
{demo:close name='demo_name'} {$key}=>{$demo_name}{/demo:close}
{demo:close name='demo_name' type='1'} {$key}=>{$demo_name}
{/demo:close} ~~~