您好,登錄后才能下訂單哦!
小編給大家分享一下ThinkPHP無限分類的使用示例,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
本文實例展示了ThinkPHP自動填充實現無限級分類的方法,是ThinkPHP常用功能之一,非常具有實用價值。現將完整實例分享給大家,供大家參考。
ThinkPHP無限分類的使用
具體實現步驟如下(本文采用TP框架的3.1.3版本):
第一步:表aoli_cate如下圖所示
CREATE TABLE `fenlei` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '主鍵', `name` varchar(255) DEFAULT NULL COMMENT '父id', `pid` int(255) NOT NULL COMMENT '名字', `path` varchar(20) DEFAULT NULL,//path字段是給數據排序用 PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=15 DEFAULT CHARSET=utf8; insert into fenlei(id,name,pid,path) values (1,’新聞’,0,’0’), (2,’中國新聞’,1,’0-1’),//path 最后一個數據是排序用的 (3,’美國新聞’,1,’0-1’), (4,’北京新聞’,2,’0-1-2’), (5,’華盛頓新聞’,3,’0-1-3’), (6,’日本新聞’,1,’0-1’);
第二步:action部分
aoli/Home/Lib/Action/CataAction.class.php文件如下:
<?php class CateAction extends Action{ function index(){ //實例化cate $cate=M('cate'); //獲取數據 //將path和id連接起來,組合成為bpath數組 $list=$cate->field("id,name,pid,path,concat(path,'-',id) as bpath")->order('bpath')->select(); foreach($list as $key=>$value){ //在查詢獲取的數組里面增加一個'count'數組; //統計bpath字段的字符串個數,并賦值給'count'數組。 $list[$key]['count']=count(explode('-',$value['bpath'])); } //展示數據 $this->assign('alist',$list); $this->display(); } //添加欄目 function add(){ //實例化CateModel類 $cate=new CateModel(); //如果從CateModel模型接受數據成功 if($vo=$cate->create()){ //執行添加 if($cate->add()){ $this->success('添加欄目成功'); }else{ $this->error('添加欄目失敗'); } //dump($vo); }else{ //返回錯誤信息 $this->error($cate->getError()); } } } ?>
第三步:模型部分
aoli/Home/Lib/Model/CataModel.class.php文件如下:
<?php class CateModel extends Model{//對應數據庫中的表aoli_cate //在Model類定義 $_auto 屬性,可以完成數據自動處理功能,用來處理默認值、數據過濾以及其他系統寫入字段。$_auto屬性是由多個填充因子組成的數組。 protected $_auto=array( //示例 //對name字段在新增的時候回調getName方法 //array('name','getName',1,'callback'), //'path'填充字段 //'tclm'回調函數 // 3 新增數據和更新數據的時候都處理 // callback :回調方法 ,表示填充的內容是一個當前模型的方法 array('path','tclm',3,'callback'), ); //回調函數 function tclm(){ //如果pid存在,就轉成整形,不存在就賦值0,表示是根目錄 $pid=isset($_POST['pid'])?(int)$_POST['pid']:0; //可以查看pid //echo ($pid); //如果是根目錄,就是在select表單沒有選任何值提交的時候 if($pid==0){ // $data=0; }else{ //如果id和pid相等 $list=$this->where("id=$pid")->find(); //把回調值$data賦值 $data=$list['path'].'-'.$list['id'];//子類的path為父類的path加上父類的id } //回調值 return $data; } } ?>
第四步:view視圖部分
<!--提交到本類的add方法--> <form action="__URL__/add" method="post"> //size="20"可以將select 框變大 請選擇父級欄目:<select name="pid" size="20"> //value="0"表示為根目錄 <option value="0">根欄目</option> //展示數據 <volist name="alist" id="vo"> <option value="{$vo['id']}"> <php> <!--以字段count統計出來的,path字段里面含的字符串來做總數--> for($i=0;$i<$vo['count'];$i++){ //在值前面添加空格 echo '; } </php> //輸出值 {$vo['name']} </option> </volist> </select><br /> 新的欄目名稱:<input type="text" name="name" /><br /> <input type="submit" value="添加欄目" /> </form>
以上是“ThinkPHP無限分類的使用示例”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。