ThinkPHP示例之自定义标签:定义查询数据库的标签
本示例定义一个查询数据库的标签,可以使模板直接按条件查找指定的数据库并列表显示,本例仅是展示自定义标签的方便之处,可以进一步扩充和完善,打造属于自已的标签体系序列 | 标题 | 内容 |
{$article.id} | {$article.title} | {$article.content} |
示例源码 控制器自定义标签类 |
thinkPHP2.1自定义标签库的导入方法详解
本文详细讲述了thinkPHP2.1自定义标签库的导入方法。分享给大家供大家参考,具体如下:
TP的手册似乎跟不上节奏, 对自定义标签只是寥寥几句, 摸索了N久, 终于将自定义的标签进行了导入. 心得如下:
1. 情况: 新建自定义的标签库类: @.Mylib.Tag.TagLibTest — 懂TP的应该知道这代表的路径
使用Examples下的Tag演示文件
// +------------------------------------------------------------
// $Id$
import('TagLib');
class TagLibArticle extends TagLib{
// 标签定义
protected $tags = array(
// 标签定义:
//attr 属性列表 close 是否闭合(0 或者1 默认1) alias 标签别名 level 嵌套层次
'article'=>array('attr'=>'name,field,limit,order,where,sql,key,mod','level'=>3),
);
//定义查询数据库标签
public function _article($attr,$content) {
$tag = $this->parseXmlAttr($attr,'article');
$result = !empty($tag['result'])?$tag['result']:'article'; //定义数据查询的结果存放变量
$key = !empty($tag['key'])?$tag['key']:'i';
$mod = isset($tag['mod'])?$tag['mod']:'2';
if ($tag['name'])
{ //根据用户输入的值拼接查询条件
$sql = "M('{$tag['name']}')->";
$sql .= ($tag['field'])?"field({$tag['field']})->":'';
$sql .= ($tag['order'])?"order({$tag['order']})->":'';
$sql .= ($tag['where'])?"where({$tag['where']})->":'';
$sql .= "select()";
}else{
if (!$tag['sql']) return ''; //排除没有指定model名称,也没有指定sql语句的情况
$sql .= "M()->query('{$tag['sql']}')";
}
//下面拼接输出语句
$parsestr = '$'.$result.'):';
$parsestr .= '++$'.$key.';$mod = ($'.$key.' % '.$mod.' );?>';
$parsestr .= $content;//解析在article标签中的内容
$parsestr .= '';
return $parsestr;
}
}
?>
然后在项目下的Conf目录新建taglibs.php文件, 内容:
'@.TagLib.TagLibarticle',
);
?>
这样就可以模板里使用了:
序列 | 标题 | 内容 |
{$article.id} | {$article.title} | {$article.content} |
示例源码 控制器自定义标签类 |