时间:2021-05-26
本文实例为大家分享了thinkphp5使用无限极分类的具体代码,供大家参考,具体内容如下
1. 先根据普通递归完成无限极分类
2. 再根据分号的类的level 添加字符,再次存入数组的_name字段,最后按照_name字段输出
/** * 获得树状数据 * @param $data 数据 * @param $title 数据库中字段名 * @param string $fieldPri 数据库中主键id * @param string $fieldPid 数据库中父id * @return array */ static public function tree($data, $title, $fieldPri = 'cid', $fieldPid = 'pid') { if (!is_array($data) || empty($data)) return array(); $arr = Data::channelList($data); foreach ($arr as $k => $v) { $str = ""; if ($v['_level'] > 2) { for ($i = 1; $i < $v['_level'] - 1; $i++) { $str .= "│ "; } } if ($v['_level'] != 1) { $t = $title ? $v[$title] : ""; if (isset($arr[$k + 1]) && $arr[$k + 1]['_level'] >= $arr[$k]['_level']) { $arr[$k]['_name'] = $str . "├─ " . $v['_html'] . $t; } else { $arr[$k]['_name'] = $str . "└─ " . $v['_html'] . $t; } } else { $arr[$k]['_name'] = $v[$title]; } } //设置主键为$fieldPri $data = array(); foreach ($arr as $d) { $data[$d[$fieldPri]] = $d; } return $data; }/** * 获得所有子栏目 * @param $data 栏目数据 * @param int $pid 操作的栏目 * @param string $html 栏目名前字符 * @param string $fieldPri 表主键 * @param string $fieldPid 父id * @param int $level 等级 * @return array */ static public function channelList($data, $pid = 0, $html = " ", $fieldPri = 'cid', $fieldPid = 'pid', $level = 1) { $data = self::_channelList($data, $pid, $html, $fieldPri, $fieldPid, $level); if (empty($data)) return $data; foreach ($data as $n => $m) { if ($m['_level'] == 1) continue;//结束单次循环 $data[$n]['_first'] = false; $data[$n]['_end'] = false; if (!isset($data[$n - 1]) || $data[$n - 1]['_level'] != $m['_level']) { $data[$n]['_first'] = true; } if (isset($data[$n + 1]) && $data[$n]['_level'] > $data[$n + 1]['_level']) { $data[$n]['_end'] = true; } } //更新key为栏目主键 $category=array(); foreach($data as $d){ $category[$d[$fieldPri]]=$d; } return $category; }//只供channelList方法使用 /** * 获得所有子栏目 * @param $data 栏目数据 * @param int $pid 操作的栏目 * @param string $html 栏目名前字符 * @param string $fieldPri 表主键 * @param string $fieldPid 父id * @param int $level 等级 * @return array */ static private function _channelList($data, $pid = 0, $html = " ", $fieldPri = 'cid', $fieldPid = 'pid', $level = 1) { if (empty($data)) return array(); $arr = array(); foreach ($data as $v) { $id = $v[$fieldPri]; if ($v[$fieldPid] == $pid) { $v['_level'] = $level; $v['_html'] = str_repeat($html, $level - 1); $arr[] = $v; $tmp = self::_channelList($data, $id, $html, $fieldPri, $fieldPid, $level + 1); $arr = array_merge($arr, $tmp);//array_merge把两个数组整合为一个数组 } } return $arr; }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了php无限极分类实现方法。分享给大家供大家参考,具体如下:今天给大家带来的是php的无限极分类技术,本人把无限极分类划分为两种。首先我把数据库表给
本文实例讲述了php通过前序遍历树实现无需递归的无限极分类。分享给大家供大家参考。具体如下:大家通常都是使用递归实现无限极分类都知道递归效率很低,下面介绍一种改
本文实例讲述了PHP实现无限极分类的两种方式。分享给大家供大家参考,具体如下:面试的时候被问到无限极分类的设计和实现,比较常见的做法是在建表的时候,增加一个PI
你还在用浪费时间又浪费内存的递归遍历无限极分类吗,看了该篇文章,我觉得你应该换换了。这是我在OSChina上看到的一段非常精简的PHP无限极分类生成树方法,巧在
本文实例讲述了thinkPHP实现递归循环栏目并按照树形结构无限极输出的方法。分享给大家供大家参考,具体如下:这里使用thinkphp递归循环栏目按照树形结构无