首頁 >後端開發 >php教程 >如何創建無限極分類樹型結構

如何創建無限極分類樹型結構

小云云
小云云原創
2018-02-12 13:17:051948瀏覽

本文主要為大家帶來一篇創建無限極分類樹型結構的簡單方法。小編覺得蠻不錯的,現在就分享給大家,也給大家做個參考。一起跟著小編過來看看吧,希望能幫助大家。

先上效果圖

頂級分類其實就是一級分類,二級分類也叫作一級分類的子分類,在這個基礎上,子分類還可以擁有子分類,這樣就構成了無限極分類。

接下來看具體實現的程式碼:

一、在控制器中按字段查詢,查詢出所有分類資訊(id:該分類的ID值,cate_name:該分類的名稱,pid:父ID,sorts:為顯示標題順序排序做準備,可不寫。

1.查詢所有分類信息,並呼叫生成分類樹方法:

public function cate_display()
  {
    $cate = D('Cate'); 
    $field = array('id','cate_name','pid','sorts');
    $list = $cate->allCategory($field);
    $this->assign('list',$list);
    $this->display();
  }

2.產生分類樹(使用遞歸,傳進去數據,以及pid[父類id],level[層數,用來控制顯示的-數量]兩個變量,初始值為零)

public function allCategory($field='*'){
     $data = $this->field($field)->select();
     return $this->tree($data);
   }

三、視圖文件中的代碼

public function tree($data,$pid=0,$level=0){
    static $tree = array();
    foreach($data as $k=>$v){
      if($v['pid'] == $pid){
        $v['level'] = $level;
        $tree[]=$v;
        $this->tree($data,$v['id'],$level+1);
      }
    }
  
    return $tree;
  }

這樣,一個可以無限遞歸的分類樹形結構就完成了,總結:核心思想還是模型中的遞歸函數,先傳入去pid預設為零,以後每次遞歸傳入的pid就是上級的id,level用來記錄遞歸層數,最後在視圖頁面顯示時,呼叫PHP內建函數str_repeat(),用來重複輸出'-'以達到輸出時區分級數的效果。

相關推薦:

php無需遞歸實現無限極分類樹

php無限極分類產生分類樹的實現方法介紹

有關無限極分類樹型結構簡單介紹

#

以上是如何創建無限極分類樹型結構的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn