nosilence 发表于 2017-4-4 06:23:03

PHP > 无限级分类生成树方法

你还在用浪费时间又浪费内存的递归遍历无限极分类吗,看了该篇文章,我觉得你应该换换了。
这是我在OSChina上看到的一段非常精简的PHP无限极分类生成树方法,巧在引用,整理分享了。
 
 

function generateTree($items){
$tree = array();
foreach($items as $item){
if(isset($items[$item['pid']])){
$items[$item['pid']]['son'][] = &$items[$item['id']];
}else{
$tree[] = &$items[$item['id']];
}
}
return $tree;
}
$items = array(
1 => array('id' => 1, 'pid' => 0, 'name' => '安徽省'),
2 => array('id' => 2, 'pid' => 0, 'name' => '浙江省'),
3 => array('id' => 3, 'pid' => 1, 'name' => '合肥市'),
4 => array('id' => 4, 'pid' => 3, 'name' => '长丰县'),
5 => array('id' => 5, 'pid' => 1, 'name' => '安庆市'),
);
print_r(generateTree($items));

 

Array
(
=> Array
(
=> 1
=> 0
=> 安徽省
=> Array
(
=> Array
(
=> 3
=> 1
=> 合肥市
=> Array
(
=> Array
(
=> 4
=> 3
=> 长丰县
)
 
)
 
)
 
=> Array
(
=> 5
=> 1
=> 安庆市
)
 
)
 
)
 
=> Array
(
=> 2
=> 0
=> 浙江省
)
 
)

 
上面生成树方法还可以精简到5行:

function generateTree($items){
foreach($items as $item)
$items[$item['pid']]['son'][$item['id']] = &$items[$item['id']];
return isset($items['son']) ? $items['son'] : array();
}

 

/**
* 如何取数据格式化的树形数据
* @blog<http://www.phpddt.com>
*/
$tree = generateTree($items);
function getTreeData($tree){
foreach($tree as $t){
echo $t['name'].'<br>';
if(isset($t['son'])){
getTreeData($t['son']);
}
}
}
getTreeData($tree);

 
页: [1]
查看完整版本: PHP > 无限级分类生成树方法