首頁  >  文章  >  後端開發  >  PHPTree-php快速產生無限級分類_php技巧

PHPTree-php快速產生無限級分類_php技巧

不言
不言原創
2018-04-04 10:20:324392瀏覽

在開發中經常需要用到樹狀數據,例如無限多層次分類,就是典型的樹狀結構。這裡面的演算法,用到了遞歸思想,為了簡化開發過程,我編寫了一個工具來提升開發效率,需要的朋友可以參考下

它就是PHPTree。

git位址:https://git.oschina.net/jiusem/PHPTree.git

或從腳本之家下載http://www.jb51.net/codes/606002. html

最簡單的範例:

##

<?php 
require(&#39;PHPTree.class.php&#39;);

//原始数据, 从数据库读出
$data = array(
	array(
		&#39;id&#39;=>1,
		&#39;name&#39;=>&#39;book&#39;,
		&#39;parent_id&#39;=>0
	),
	array(
		&#39;id&#39;=>2,
		&#39;name&#39;=>&#39;music&#39;,
		&#39;parent_id&#39;=>0
	),
	array(
		&#39;id&#39;=>3,
		&#39;name&#39;=>&#39;book1&#39;,
		&#39;parent_id&#39;=>1
	),
	array(
		&#39;id&#39;=>4,
		&#39;name&#39;=>&#39;book2&#39;,
		&#39;parent_id&#39;=>3
	)
);

$r = PHPTree::makeTree($data);
echo json_encode($r);

?>

#輸出:

  [

        {
"id": 1,
            "name": "book",
            "name": "          "children": [
                {
                  name": "book1",
                    "parent_id": 1,
                      "children": [
                        {
                                    "name": "book2",
      
                            "leaf": true
                     ]
                }
            ]
      : 2,

            "name": "music",
            "parent_id": 0,
"leaf": true
        }
]


#產生的資料是樹狀結構了,可以結合ExtJS等前端架構來使用了。 git包含了一個ExtJS的demo,大家可以參考。


示範:



如果不需要使用前端框架,只是用HTML輸出,可以使用下面的方法:

# $r = PHPTree::makeTreeForHtml($data);

得到一個一維數組,用level 欄位來識別分類的層次:

##
array(
 array(
  &#39;id&#39;=>1,
  &#39;name&#39;=>&#39;用户管理&#39;,
  &#39;parent_id&#39;=>0,
  &#39;level&#39;=>0 //一级分类
 ),
 array(
  &#39;id&#39;=>1,
  &#39;name&#39;=>&#39;用户列表&#39;,
  &#39;parent_id&#39;=>1,
  &#39;level&#39;=>1 //二级分类
 )
 ....
);

輸出為select標籤:

echo &#39;<h1>PHPTree树形结构</h1>&#39;;
echo &#39;<select style="width:300px;">&#39;;
foreach($r as $item){
	echo &#39;<option>&#39;;
	//根据所在的层次缩进
	echo str_repeat(&#39;......&#39;,$item[&#39;level&#39;]);
	echo $item[&#39;name&#39;];
	echo &#39;</option>&#39;;
}
echo &#39;</select>&#39;;

#示範:

git中包含了一個輸出HTML的demo,大家可以參考。

關於資料庫的設計,只需要保證包含 id 和 parent_id 欄位即可,其他欄位可以自行添加,不會影響資料產生。 parent_id是父級ID,如果是一級分類,就設為 0 。當然,欄位也是可以配置的。請繼續往下看,我將介紹一些進階的使用方法。

展開子節點:

PHPTree::makeTree( $data, array(
 &#39;expanded&#39; => true
));

输出的数据为:

[
        {
            id:1,
            name:'book1',
            expanded:true,//展开子节点
            children:[
                ...
            ]
        }
]

自定义主键和父键:

//数据库读出
$data = array(
 array(
  &#39;order_id&#39;=>1, //主键
  &#39;name&#39;=>&#39;book1&#39;,
  &#39;pid&#39;=>0, //父键
  ...
 )
);
PHPTree::makeTree( $data, array(
 &#39;primary_key&#39; => &#39;order_id&#39;,
 &#39;parent_key&#39; => &#39;pid&#39;
));

输出的数据为:

[
        {
            order_id:1,
            name:'book1',
            pid:0,
            ...
        }
]

makeTreeForHtml 方法也支持配置主键和父键。

还有其他字段也可以自定义,但下面这些参数仅支持 makeTree 方法:

$r = PHPTree::makeTree($data, array(
 &#39;expanded_key&#39; => &#39;expanded&#39;,
 &#39;children_key&#39; => &#39;children&#39;,
 &#39;leaf_key&#39;  => &#39;leaf&#39;
));

默认,这些字段的配置都是以ExtJS为参考的,如果你使用zTree框架的话,这些字段就需要重新配置了。

zTree 是一款强大的国产树形框架,它还支持 简单JSON格式,是一维数据格式,实际上就不需要用到PHPTree了。当然,PHPTree输出的数据层次感清晰,zTree也是支持的。

相关推荐:

php递归实现无限级分类的开发过程及示例代码

php 实现无限级分类的三种方式

php无限级分类实现方法分析

以上是PHPTree-php快速產生無限級分類_php技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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