我们最终想要的结果是这样子的!(不怕大家笑话,这一点我请一个朋友帮的忙才解决的!)
//整理后的分类数据
$output_array = array(
array(
'id' => 1,
'pid' => 0,
'name' => '新闻分类',
'children' => array(
array(
'id' => 3,
'pid' => 1,
'name' => '国内新闻'
),
array(
'id' => 4,
'pid' => 1,
'name' => '国际新闻'
),
),
),
array(
'id' => 2,
'pid' => 0,
'name' => '最新公告',
),
array(
'id' => 5,
'pid' => 0,
'name' => '图片分类',
'children' => array(
array(
'id' => 6,
'pid' => 5,
'name' => '新闻图片'
),
array(
'id' => 7,
'pid' => 5,
'name' => '其它图片'
),
),
),
);
很明显,这里数组多了一个字段,就是 children!
那么,怎么 从 $original_array 变为 $output_array呢?这里有我一个朋友做的函数,当然也用到 foreach!
函数如下:
//整理函数
/**
* 生成无限级树算法
* @author Baiyu 2014-04-01
* @param array $arr 输入数组
* @param number $pid 根级的pid
* @param string $column_name 列名,id|pid父id的名字|children子数组的键名
* @return array $ret
*/
function make_tree($arr, $pid = 0, $column_name = 'id|pid|children') {
list($idname, $pidname, $cldname) = explode('|', $column_name);
$ret = array();
foreach ($arr as $k => $v) {
if ($v [$pidname] == $pid) {
$tmp = $arr [$k];
unset($arr [$k]);
$tmp [$cldname] = make_tree($arr, $v [$idname], $column_name);
$ret [] = $tmp;
}
}
return $ret;
}
那们怎么使用呢?
//整理函数的使用 $output_array = make_tree($original_array);
完整使用方法如下:
$output_array =make_tree($arr, 0, 'id|pid|children')
函数之后,我们这样调用就得到了一级分类与二级分类!
foreach ($output_array as $key => $value) {
echo '<h2>'.$value['name'].'</h2>';
foreach ($value['children'] as $key => $value) {
echo $value['name'].',';
}
结果如下:

附:$output_array 这个数组,我们使用print_r,就可以得到如下的结果!
Array
(
[0] => Array
(
[id] => 1
[pid] => 0
[name] => 新闻分类
[children] => Array
(
[0] => Array
(
[id] => 3
[pid] => 1
[name] => 国内新闻
[children] => Array
(
)
)
[1] => Array
(
[id] => 4
[pid] => 1
[name] => 国际新闻
[children] => Array
(
)
)
)
)
[1] => Array
(
[id] => 2
[pid] => 0
[name] => 最新公告
[children] => Array
(
)
)
[2] => Array
(
[id] => 5
[pid] => 0
[name] => 图片分类
[children] => Array
(
[0] => Array
(
[id] => 6
[pid] => 5
[name] => 新闻图片
[children] => Array
(
)
)
[1] => Array
(
[id] => 7
[pid] => 5
[name] => 其它图片
[children] => Array
(
)
)
)
)
)







