function tree($arr,$arr2=array(),$per_id=0,$lv=0){
static $i=0; //从0开始
if ((bool)$arr) {
foreach ($arr as $value) {
if ($value['col_pid']==$per_id) {
$value['count']=$lv;
$arr2[$i]=$value;
$i++;
$lv++;
self::tree($arr,$arr2,$value['col_id'],$lv--);
}
}
}
}
调用self::tree($rlist,$column);
$rlist是要遍历的数组,$column是用来接收遍历好的数组
tree方法里面参数说明
$arr=$rlist;
$arr2=$column
$per_id是一个复值传参的作用
$lv统计数组层数赋值给$value['count']
<pre name="code" class="php">$value['col_pid']菜单的上级菜单id
<pre name="code" class="php">$value['col_id']菜单主键id
主要用在商品分类,菜单分类,导航,后台里面
下面说说我的数据库设计是怎样的,如果上面还没有理解应该看这个差不多会懂了
主键自增id int not null为空填充0对应菜单col_id 菜单名称
col_id col_pid title
1 0 菜单1
2 1 菜单1子菜单
3 0 菜单2
4 1 菜单1子菜单
5 3 菜单2子菜单
当然这个只是简单的多维数组处理
2016年12月14号补充前面不知道为什么我环境升级一下不行了
functiontree(&$list,$pid=0,$level=0,$html='--'){
static $tree= array();
foreach($list as $v){
if($v['pid'] == $pid){
$v['sort'] = $level;
$v['html'] = str_repeat($html,$level);
$tree[] = $v;
tree($list,$v['id'],$level+1);
}
}
return$tree;
}
static $tree= array();
foreach($list as $v){
if($v['pid'] == $pid){
$v['sort'] = $level;
$v['html'] = str_repeat($html,$level);
$tree[] = $v;
tree($list,$v['id'],$level+1);
}
}
return$tree;
}
2018年07月04号补充一下这种事拼在下面子类上面
function list_to_tree($list, $pk='id', $pid = 'pid', $child = '_child', $root = 0) { // 创建Tree $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]; } else { if (isset($refer[$parentId])) { $parent =& $refer[$parentId]; $parent[$child][] =& $list[$key]; } } } } return $tree; }