数组菜单分类

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号补充前面不知道为什么我环境升级一下不行了

http://blog.sina.com.cn/s/blog_75ad10100101mrv0.html


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;
}


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;
}




 
 
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值