Rumah  >  Artikel  >  pembangunan bahagian belakang  >  php如何实现无限极分类?(附代码)

php如何实现无限极分类?(附代码)

不言
不言asal
2018-08-13 15:09:142221semak imbas

本篇文章给大家带来的内容是关于php如何实现无限极分类?(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

在写项目的时候用到了无限极分类,因为项目的特殊原因,菜单栏需要多次调用该方法,用静态变量保存数组的时候就会出现问题,所以选择了引用的方法

public function getTree($array, $pid = 0, $level = 0, &$list)
    {
        foreach ($array as $key => $value) {            
        //第一次遍历,找到父节点为根节点的节点 也就是pid=0的节点
            if ($value['parentid'] == $pid) {                
            //父节点为根节点的节点,级别为0,也就是第一级
                $value['level'] = $level;                
                //把数组放到list中
                $list[] = $value;                
                //把这个节点从数组中移除,减少后续递归消耗
                unset($array[$key]);                
                //开始递归,查找父ID为该节点ID的节点,级别则为原级别+1
                $this->getTree($array, $value['id'], $level + 1, $list);

            }
        }        
        return $list;
    }

相关推荐:

php如何实现分类树状的效果?(附代码)

用php怎么获取文件的大小进行判断?(代码示例)

Atas ialah kandungan terperinci php如何实现无限极分类?(附代码). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn