当前位置:编程学堂 > 无限分类php_PHP无限分类功能实现方法详解

无限分类php_PHP无限分类功能实现方法详解

  • 发布:2023-09-29 11:58

本文介绍了PHP无限分类功能的实现方法。分享给大家参考,详情如下:

在开发程序时,有时我们需要获取所有列(包括一级列、二级列、三级列等),并根据父子关系形成树形结构。您可以使用递归或引用(php 中的引用类似于 C 或 C++ 中的指针,只是另一种说法)。

通过引用进行无限极分类

想法:

1。即将所有待处理的数据打包成一个下标为主键id(pk)的数组,这样就可以通过pid获取对应的父列。

2。循环遍历打包的数据,如果是根节点,则添加其对树的引用,否则,添加其父类的子元素的引用。这样,虽然只将根节点添加到树中,但如果每个根节点包含 子元素,则它包含对 子元素 的引用。因此,它可以形成树的形状。

代码如下

/**

* 将返回的数据集转换成Tree

* @param array $list 待转换的数据集

* @param string $pk 自增字段(列id)

* @param string $pid 父标记字段

* @返回数组

* @作者 dqs

*/

函数make_tree($list,$pk='id',$pid='pid',$child='_child',$root=0){

$tree=array();

$packData=数组();

foreach($list 作为$data){

$packData[$data[$pk]] = $data;

}

foreach($packData 作为 $key =>$val){

if($val[$pid]==$root){//代表节点

$tree[]=& $packData[$key];

}其他{

//查找其父类

$packData[$val[$pid]][$child][]=& $packData[$key];

}

}

返回$tree;

}

数据结构如下:

执行结果如下

数组

(

[0] => 数组

(

[id] => 6

[pid] => 0

[标题] => 测试 1

[url] => 测试1

[排序] => 0

[创建时间] => 1464076199

[更新时间] => 1464076199

[状态] => 1

[目标] => 0

)

[1] => 数组

(

[id] => 7

[pid] => 0

[标题] => 测试 2

[url] => test2

[排序] => 0

[创建时间] => 1464076218

[更新时间] => 1464076218

[状态] => 1

[目标] => 0

)

[2] => 数组

(

[id] => 1

[pid] => 0

[title] => 首页

[url] => 索引/索引

[排序] => 1

[创建时间] => 1379475111

[更新时间] => 1379923177

[状态] => 1

[目标] => 0

)

[3] => 数组

(

[id] => 2

[pid] => 0

[标题] => 博客

[url] => 文章/索引?category=博客

[排序] => 2

[创建时间] => 1379475131

[更新时间] => 1379483713

[状态] => 1

[目标] => 0

[_child] => 数组

(

[0] => 数组

(

[id] => 4

[pid] => 2

[title] => 个人博客

[url] => 自己的博客

[排序] => 0

[创建时间] => 1464075558

[更新时间] => 1464075558

[状态] => 1

[目标] => 0

[_child] => 数组

(

[0] => 数组

(

[id] => 8

[pid] => 4

[标题] => 新浪博客

[url] => 新浪博客

[排序] => 0

[创建时间] => 1464077276

[更新时间] => 1464077276

[状态] => 1

[目标] => 0

)

)

)

[1] => 数组

(

[id] => 5

[pid] => 2

[标题] => 别人的博客

[url] => 其他博客

[排序] => 0

[创建时间] => 1464075582

[更新时间] => 1464075582

[状态] => 1

[目标] => 0

)

)

)

[4] => 数组

(

[id] => 3

[pid] => 0

[标题] => 官方网站

[url] => http://www.sychzs.cn

[排序] => 3

[创建时间] => 1379475154

[更新时间] => 1387163458

[状态] => 1

[目标] => 0

)

)

OneThink 新增无限极分类功能

/**

* 将返回的数据集转换成Tree

* @param array $list 待转换的数据集

* @param string $pid 父标记字段

* @param string $level 级别标记字段

* @返回数组

* @作者麦当妙儿

*/

函数list_to_tree($list, $pk='id', $pid = 'pid', $child = '_child', $root = 0) {

//创建树

$tree = array();

if(is_array($list)) {

// 根据主键创建数组引用

$refer = array();

foreach($list as $key => $data){

$refer[$data[$pk]] =& $list[$key];

}

foreach($list as $key => $data){

//判断parent

是否存在

$parentId = $data[$pid];

if ($root == $parentId) {

$tree[] =& $list[$key];

}其他{

if (isset($refer[$parentId])) {

$parent =& $refer[$parentId];

$parent[$child][] =& $list[$key];

}

}

}

}

返回$tree;

}

通过递归进行无限分类

想法:

1。使用循环分别获取所有根节点。

2。获取每个节点时,从原始数据中删除该节点,并递归获取其所有子节点,直到原始数据为空。

代码实现如下:

函数make_tree1($list,$pk='id',$pid='pid',$child='_child',$root=0){

$tree=array();

foreach($list as $key=> $val){

if($val[$pid]==$root){

//获取当前$pid的所有子类

unset($list[$key]);

if(!empty($list)){

$child=make_tree1($list,$pk,$pid,$child,$val[$pk]);

if(!empty($child)){

$val['_child']=$child;

}

}

$tree[]=$val;

}

}

返回$tree;

}

效果截图如下:

希望这篇文章对大家PHP编程有所帮助。

相关文章