程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> ThinkPHP標簽制作教程

ThinkPHP標簽制作教程

編輯:PHP綜合

本文以實例講解了ThinkPHP標簽的制作方法,對於ThinkPHP的初學者或者開發人員都有一定的借鑒價值。

一般來說,ThinkPHP的默認標簽解析器在Lib/Template/TagLib/TagLibCx.class(2.1版本位於ThinkPHP/Lib/Think/Template/TagLib/TagLibCx.class.php)中,裡面定義了常用的如volist php 等常用ThinkPHP的標簽

這裡我們就在這個類中添加一個<category>的標簽解析。
 
一、標簽格式:

<category parentid='0' ><{$cat.catname}></category>

二、標簽作用:

循環輸出父類id是parentid的欄目

三、操作步驟:

1.在tagLibCx.class 的私有屬性中添加:

'category'=array('attr'=>'parentid',level=>3)

其中attr:標簽的屬性 level標簽的嵌套層次
 
2.添加解析函數

標簽的解析原理就是通過讀取xml文件得到相應的信息,然後再拼湊成所需要的php源代碼,最後通過echo 在頁面上輸出。

具體代碼如下:

public function _category($attr,$content)
{
//把標簽的所有屬性解析到$tag數組裡面
$tag = $this->parseXmlAttr($attr,'category');
//得到標簽裡面的屬性
$parentid= $tag['parentid'];
//定義頁面解析的變量
$result = !empty($tag['result'])?$tag['result']:'cat'; //定義數據查詢的結果存放變量
$key = !empty($tag['key'])?$tag['key']:'i';
$mod = isset($tag['mod'])?$tag['mod']:'2';
//拼湊數據庫查詢語句 這裡直接用了CategoryModel封裝好的函數
$sql = "D('Category')->";
$sql .= "getCategorys(".$parentid.')';
//拼湊輸出字符
$parsestr = '<?php $_result='.$sql.'; if ($_result): $'.$key.'=0;';
$parsestr .= 'foreach($_result as $key=>$'.$result.'):';
$parsestr .= '++$'.$key.';$mod = ($'.$key.' % '.$mod.' );?>';
$parsestr .= $content;//解析在category標簽中的內容
$parsestr .= '<?php endforeach; endif;?>';
return $parsestr;
}

CategoryModel中的getCategorys方法:

/*
* 根據parentid得到欄目信息
* $parentid 父id
* $withSelf 是否包含自己
*/
public function getCategorys($parentid,$withSelf=0)
{
$parentid=intval($parentid);
$categorys=$this->where(array('parentid'=>$parentid,'ismenu'=>1))->order('listorder ASC')->select();
//包含自己
if($withSelf)
{
$categorys2=$this->where(array('id'=>$parentid,'ismenu'=>1))->limit(1)->select();
$category=array_merge($categorys,$categorys2);
}
return $categorys;
}

3.頁面上的引用:

<category parentid='0'>
<{$cat.catname}>
</category>

這樣一個標簽就做好了!!就可以甩掉那個volist在頁面上動態輸出我們想要的東西了!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved