thinkphp中如何实现无限级分类?
thinkphp中如何实现无限级分类?
一、总结
1、数据表设计+递归算法
二、php实现无限级分类实例总结
1、数据库数据如下:

2、任务需求:给一个id,求自己和所有父亲。
3、实现代码如下:thinkphp中的模型层
<?php
namespace app\index\model;
use think\Model; class Base extends Model
{ //递归具体将数据按照从父亲到孩子开始排序
public function recursionSortModule($modules,$pid=0){
static $arr=array();
foreach ($modules as $k => $v) {
if ($v['pid']==$pid) {
$arr[]=$v;
$this->recursionSortModule($modules,$v['id']);
}
}
return $arr;
} // 将数据按照从父亲到孩子开始排序
public function sortModule(){
$modules=db('module')->select();
$sortModules=$this->recursionSortModule($modules);
return $sortModules;
} // 需求:根据一个moduleid,获取它自己以及他的所有父亲
public function getAllParents($id){
//1、将数据按照从父亲到孩子开始排序
$sortModules=$this->sortModule();
//2、从排序好的数组由下往上取出自己以及它的所有父亲
$ans=array();
foreach (array_reverse($sortModules) as $key => $value) {
if ((int)$value['id']==(int)$id) {
$ans[]=$value;
$id=$value['pid'];
}
}
return array_reverse($ans);
} }
4、性能分析:
其实感觉这样排序后找的效果还不如直接递归拿自己和父亲
三、测试题-简答题
1、无限分类的数据表设计有哪些核心字段?
解答:核心字段:id,pid。
2、无限分类的本质是哪种数据结构?
解答:树,树的核心操作就是递归,所以无限分类一般都是递归。
3、无限分类一般是用哪种算法来实现的?
解答:递归,因为无限分类的本质是树,而树的核心算法就是递归,所以无限分类一般都是递归算法。当然栈也可以。
4、无限分类算法的起始是什么?
解答:依次找pid为0的数据。
5、无限分类递归算法实现中递归的参数是什么?
解答:数组数据和pid,如果数据表里面没有记录level字段,如果需要在递归中求level字段,参数可以加上level。
6、无限分类递归的排序算法是什么?
解答:依次找pid为0的数据,对每个pid为0的数据,递归找他们的所有孩子。
7、静态数组的作用是什么?
解答:保证数组数据独一份,即使在递归中也保证数组数据是全局的,是一份的。
8、php中的静态数组如何实现?
解答:static $arr=array();
9、如何实现foreach的逆序输出?
解答:用array_reverse(), foreach (array_reverse($sortModules) as $key => $value)。
thinkphp中如何实现无限级分类?的更多相关文章
- ThinkPHP自动填充实现无限级分类的方法
这篇文章主要介绍了ThinkPHP自动填充实现无限级分类的方法,是ThinkPHP项目开发中非常实用的一个技巧,需要的朋友可以参考下 本文实例展示了ThinkPHP自动填充实现无限级分类的方法,是 ...
- Thinkphp的list_to_tree 实现无限级分类列出全部节点
list_to_tree 使用起来十分方便,具体可查看手冊.由于我在用的时候须要同一时候列出全部节点,所以写了一个递归函数,拿出来供大家參考. public function index(){ Loa ...
- thinkphp框架中使用递归实现无限级分类
无限级分类在我们开发中显得举足轻重,会经常被人问到,而一般会用递归的方法来实现,但是递归又会难倒一批人.今天博主分享的这个稍微有点基础的phper都能学会,希望大家能喜欢. 一.先建立对应的数据库和表 ...
- thinkphp实现无限级分类
普通的方法(采用for和foreach) //显示 foreach($data as $k=>$v){ //str_repeat()函数用于把字符串重复指定的次数 $data[$k]['titl ...
- ThinkPHP无限级分类
<?php // +---------------------------------------------------------------------- // | ThinkPHP [ ...
- php无限级分类实战——评论及回复功能
经常在各大论坛或新闻板块详情页面下边看到评论功能,当然不单单是直接发表评论内容那么简单,可以对别人的评论进行回复,别人又可以对你的回复再次评论或回复,如此反复,理论上可以说是没有休止,从技术角度分析很 ...
- PHP无限级分类的实现(不使用递归)
无限级分类在开发中经常使用,例如:部门结构.文章分类.无限级分类的难点在于“输出”和“查询”,例如 将文章分类输出为<ul>列表形式: 查找分类A下面所有分类包含的文章. 1.实现原理 在 ...
- ThinkPHP中疑难笔记
不但要记住核心的东西, 还要记住 相关的 东西: 如php cli的版本是 5.6.14 bulit: sep 30, 2015 tp中, 通常说的系统就是框架; 项目就是 "应用程序&qu ...
- (实用篇)PHP递归实现无限级分类
在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类. 在一些复杂的系统中,要求对信 ...
随机推荐
- 初学WCF需要注意的地方
1.WCF的元数据发布有两种方式: a.HTTP-GET方式发布数据:让客户端使用HTTP-GET方式来获取数据是比较常见的方式.所谓HTTP—GET方式,是指当客户端发送一个HTTP-GET请求时, ...
- CISP/CISA 每日一题 11
CISA 每日一题(答) 一个合理建造的数据仓库应当支持下列三种基本的查询格式: 1.向上溯源和向下溯源——向上溯源是对数据进行总计:向下溯源是将数据进行细化: 2.交叉溯源——通过通用属性访问数据仓 ...
- http 500 Internal Server Error的错误 ajax请求SpringMVC后台中返回500 Internal Server Error
使用httprequester接口测试能返回数据,但是用ajax返回json格式的时候返回报500Internal Server Error. The server encountered an in ...
- 2lession-文件访问
今天继续学习python,因为是根据网上的教程,里面用到了一些例子,包含有后面的知识点.但是,因为自己稍微有点c.java等语言基础,所以并没有严格按照教程来学习,反而是遇到知识点就记录下来. 代码如 ...
- win7桌面有个无法删除的IE图标
平台:win7 症状:安装软件时没仔细看,结果装上了一大堆,挨个卸载后桌面残留了一个IE无法删除.在该图标上点右键只有“打开”“属性”“创建快捷方式”三个选项,主页默认为www.2345.com. 解 ...
- 【算法导论-36】并查集(Disjoint Set)具体解释
WiKi Disjoint是"不相交"的意思.Disjoint Set高效地支持集合的合并(Union)和集合内元素的查找(Find)两种操作,所以Disjoint Set中文翻译 ...
- [Angular] Style HTML elements in Angular using ngStyle
We will learn how to make use of the ngStyle directive to directly add multiple style attributes to ...
- amazeui学习笔记--css(常用组件6)--图标Icon
amazeui学习笔记--css(常用组件6)--图标Icon 一.总结 1.关注用法即可:在 HTML 上添加添加 am-icon-{图标名称} class. <span class=&quo ...
- LeetCode Algorithm 01_Two Sum
Given an array of integers, find two numbers such that they add up to a specific target number. The ...
- (6)uboot具体解释——关闭缓存和mmu
uboot具体解释--关闭缓存和mmu 当设置完时钟分频以后,uboot就会运行cpu_init_crit汇编函数,这个函数的主要作用就是关闭缓存和mmu.然后调用lowlevel_init函数进行系 ...