微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

创建无限极分类树型结构的简单方法

先上效果

顶级分类其实就是一级分类,二级分类也叫作一级分类子分类在这个基础上,子分类还可以拥有子分类,这样就构成了无限极分类

接下来看具体实现的代码

一、在控制器中按字段查询查询出所有分类信息

(id:该分类的ID值,cate_name:该分类名称,pid:父ID,sorts:为显示标题顺序排序做准备,可不写。)

allCategory($field); $this->assign('list',$list); $this->display(); }

二、模型中的代码

在对应控制器的模型中创建两个方法

查询所有分类信息,并调用生成分类方法

field($field)->select(); return $this->tree($data); }

生成分类树(使用递归,传进去数据,以及pid[父类id],level[层数,用来控制显示的-数量]两个变量,初始值为零)

$v){ if($v['pid'] == $pid){ $v['level'] = $level; $tree[]=$v; $this->tree($data,$v['id'],$level+1); } }
return $tree;

}

三、视图文件中的代码

rush:xhtml;">
菜单
菜单 {$val.cate_name}

这样,一个可以无限递归的分类树形结构就完成了,总结:核心思想还是模型中的递归函数,先传进去pid认为零,以后每次递归传入的pid就是上级的id,level用来记录递归层数,最后在视图页面显示时,调用PHP内置函数str_repeat(),用来重复输出'-‘以达到输出时区分级数的效果

以上这篇创建无限极分类树型结构的简单方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

原文地址:https://www.jb51.cc/php/17261.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐