這篇文章主要介紹了thinkPHP2.1自訂標籤庫的導入方法,詳細分析了thinkPHP標籤庫的定義、使用及自動導入相關技巧,需要的朋友可以參考下
本文詳細講述了thinkPHP2.1自訂標籤庫的導入方法。分享給大家供大家參考,具體如下:
TP的手冊似乎跟不上節奏, 對自定義標籤只是寥寥幾句, 摸索了N久, 終於將自定義的標籤進行了導入. 心得如下:
1. 情況: 新建自訂的標籤庫類別: @.Mylib.Tag.TagLibTest — 懂TP的應該知道這代表的路徑
#使用Examples下的Tag示範檔案
<?php // +----------------------------------------------------------- // | ThinkPHP // +------------------------------------------------------------ // | Copyright (c) 2009 http://thinkphp.cn All rights reserved. // +------------------------------------------------------------ // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 ) // +------------------------------------------------------------ // | Author: liu21st <liu21st @gmail.com=""> // +------------------------------------------------------------ // $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 = '<?php $_result='.$sql.'; if ($_result): $'.$key.'=0;'; $parsestr .= 'foreach($_result as $key=>$'.$result.'):'; $parsestr .= '++$'.$key.';$mod = ($'.$key.' % '.$mod.' );?>'; $parsestr .= $content;//解析在article标签中的内容 $parsestr .= '<?php endforeach; endif;?>'; return $parsestr; } } ?></liu21st>
然後在專案下的Conf目錄新建taglibs.php檔案, 內容:
<?php return array( 'article'=>'@.TagLib.TagLibarticle', ); ?>
這樣就可以模板裡使用了:
<tagLib name="article" /> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>ThinkPHP示例:自定义标签</title> <link rel='stylesheet' type='text/css' href='__PUBLIC__/Css/common.css'> </head> <body> <p class="main"> <h2>ThinkPHP示例之自定义标签:定义查询数据库的标签</h2> 本示例定义一个查询数据库的标签,可以使模板直接按条件查找指定的数据库并列表显示,本例仅是展示自定义标签的方便之处,可以进一步扩充和完善,打造属于自已的标签体系 <table cellpadding=2 cellspacing=2> <thead> <tr> <td class="tLeft" width="8%">序列</td><td class="tLeft" width="12%">标题</td><td>内容</td> </tr> </thead> <article:article name="form" limit="10"> <tr> <td>{$article.id}</td> <td>{$article.title}</td> <td>{$article.content}</td> </tr> </article:article> <tr> <td colspan='3'> <hr> 示例源码<br/>控制器自定义标签类<br/> <php>highlight_file(LIB_PATH.'TagLib/TagLibarticle.class.php');</php></td> </tr> </table> </p> </body> </html>
這是很簡單的情況, 但是我的想法是要求自定義標籤庫能自動導入, 這樣就不用在每一個模板裡第一行加上類似
#只是這遇到了一點問題
2. 自動匯入自訂標籤庫
在config.php檔案裡加上:
'TAGLIB_PRE_LOAD' => 'article' ,
清除快取, 提示錯誤"實例化一個不存在的類別!" ;
使用在TP官方論壇轉了幾圈, 發現只有一個方式能解決: 使用別名導入, 即在TP框架裡的commonn/alias.php下方新增導入的路徑:
如:
'TagLibArticle' => THINK_PATH.'/Lib/Think/Template/TagLib/TagLibArticle.class.php',
還有一些修改Template類別原始碼的方案, 不好使— 因為通常我不希望為了一點小問題修改核心.
於是想到Action的導入:
在自己的專案基類BaseAction.class.php加入導入:
function _initialize() { import("@.Mylibs.Tag.TagLibArticle"); }
刷新快取, 問題解決…
這方案簡單好用.
#使用TP的自動載入配置更快捷:
'APP_AUTOLOAD_PATH'=> 'Think.Util.,@.Mylibs.Tag.',
最終方案:
1. 建立Mylibs.Tag.TagLibTest — 自訂標籤庫
2. 配置:
'APP_AUTOLOAD_PATH'=> 'Think.Util.,@.Mylibs.Tag.', 'TAGLIB_PRE_LOAD' => 'test' ,
#刪除快取後既可正常使用.
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
相關推薦:
以上是thinkPHP2.1自訂標籤庫的導入方法的介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!