## 標簽擴展
>[info]建議開發者將自定義標簽庫請放置應用目錄中,請勿放在框架系統目錄內,以免使用`Composer`更新框架時導致自定義標簽庫的丟失
下面是一個Demo標簽庫的示例:
~~~
<?php
namespace app\common\taglib;
use think\template\TagLib;
class Demo extends TagLib{
/**
* 定義標簽列表
*/
protected $tags = [
// 標簽定義: attr 屬性列表 close 是否閉合(0 或者1 默認1) alias 標簽別名 level 嵌套層次
'close' => ['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 = '<?php ';
$parse .= 'echo date("' . $format . '",' . $time . ');';
$parse .= ' ?>';
return $parse;
}
/**
* 這是一個非閉合標簽的簡單演示
*/
public function tagOpen($tag, $content)
{
$type = empty($tag['type']) ? 0 : 1; // 這個type目的是為了區分類型,一般來源是數據庫
$name = $tag['name']; // name是必填項,這里不做判斷了
$parse = '<?php ';
$parse .= '$test_arr=[[1,3,5,7,9],[2,4,6,8,10]];'; // 這里是模擬數據
$parse .= '$__LIST__ = $test_arr[' . $type . '];';
$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());
~~~
在模版中調用我們已經預先加載的標簽:
~~~
<h1>開放標簽</h1>
{demo:open time='$demo_time'/}
<hr>
<h1>閉合標簽</h1>
{demo:close name='demo_name'}
{$key}=>{$demo_name}<br>
{/demo:close}
<br>
{demo:close name='demo_name' type='1'}
{$key}=>{$demo_name}<br>
{/demo:close}
~~~