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中如何实现无限级分类?的更多相关文章

  1. ThinkPHP自动填充实现无限级分类的方法

    这篇文章主要介绍了ThinkPHP自动填充实现无限级分类的方法,是ThinkPHP项目开发中非常实用的一个技巧,需要的朋友可以参考下   本文实例展示了ThinkPHP自动填充实现无限级分类的方法,是 ...

  2. Thinkphp的list_to_tree 实现无限级分类列出全部节点

    list_to_tree 使用起来十分方便,具体可查看手冊.由于我在用的时候须要同一时候列出全部节点,所以写了一个递归函数,拿出来供大家參考. public function index(){ Loa ...

  3. thinkphp框架中使用递归实现无限级分类

    无限级分类在我们开发中显得举足轻重,会经常被人问到,而一般会用递归的方法来实现,但是递归又会难倒一批人.今天博主分享的这个稍微有点基础的phper都能学会,希望大家能喜欢. 一.先建立对应的数据库和表 ...

  4. thinkphp实现无限级分类

    普通的方法(采用for和foreach) //显示 foreach($data as $k=>$v){ //str_repeat()函数用于把字符串重复指定的次数 $data[$k]['titl ...

  5. ThinkPHP无限级分类

    <?php // +---------------------------------------------------------------------- // | ThinkPHP [ ...

  6. php无限级分类实战——评论及回复功能

    经常在各大论坛或新闻板块详情页面下边看到评论功能,当然不单单是直接发表评论内容那么简单,可以对别人的评论进行回复,别人又可以对你的回复再次评论或回复,如此反复,理论上可以说是没有休止,从技术角度分析很 ...

  7. PHP无限级分类的实现(不使用递归)

    无限级分类在开发中经常使用,例如:部门结构.文章分类.无限级分类的难点在于“输出”和“查询”,例如 将文章分类输出为<ul>列表形式: 查找分类A下面所有分类包含的文章. 1.实现原理 在 ...

  8. ThinkPHP中疑难笔记

    不但要记住核心的东西, 还要记住 相关的 东西: 如php cli的版本是 5.6.14 bulit: sep 30, 2015 tp中, 通常说的系统就是框架; 项目就是 "应用程序&qu ...

  9. (实用篇)PHP递归实现无限级分类

    在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类. 在一些复杂的系统中,要求对信 ...

随机推荐

  1. 解决sublime text3配置Python3编译环境:运行代码时提示“NO Build System”

    只需要在路径中把单杠换成双杠,重启sublime即可.

  2. 配置mysql的ODBC数据源

    如果你已经安装好了mysql和mysql连接驱动,则可以向下进行了 打开控制面板,以小图标的形式查看,找到管理工具 打开管理工具,找到数据源(odbc),打开 在图片中所圈出的三个标签中随便选一个,点 ...

  3. Arch Linux实体机安装记录

    下面将记录笔者在戴尔笔记本安装arch linux的过程,用于记录,以便下次使用. 本文的内容参考arch linux官方Wiki. 首先,使用Power ISO把镜像安装到U盘,使用U盘安装. 通过 ...

  4. UVa 11015 - 05-2 Rendezvous

    題目:有一個班級的學生要一起寫作業,所以他們要到一個統一的地點.現在給你他們各自的位置, 問集合地點定在哪,能够讓全部人走的總路徑長度最小. 分析:圖論.最短路.直接利用Floyd計算最短路,找到和值 ...

  5. perl模块 Compress::Raw::Lzma 的安装

    perl模块 Compress::Raw::Lzma 的安装 用 cpan 安装任意perl模块总是提示 Couldn't untar Compress-Raw-Lzma-2.070.tar: 'Ca ...

  6. Python编写Appium测试用例(1)

    有段时间没有使用python编写测试用例了,很长时间以来,感觉appium这个测试工具确实不错,今天又重新拿起来,分享一下自己学习的一些用例,欢迎大家一起交流.学习! 1.登录客户端 #coding= ...

  7. 巴什博奕小结 HDU2188 HDU1846 HDU2149

    摘自百度百科: 巴什博奕(Bash Game):只有一堆n个物品,两个人轮流从这堆物品中取物,规定每次至少取一个,最多取m个.最后取光者得胜. 显然,如果n=m+1,那么由于一次最多只能取m个,所以, ...

  8. Cocos2d-X开发中国象棋《八》走棋

    在上一节中实现了新局,至此中国象棋的准备工作差点儿相同都完毕了,在接下来的博客中将介绍玩家的走棋和一些游戏属性的设置,今天先介绍走棋和走棋规则 老规则,先看走棋的效果图,然后依据效果图一步一步分析游戏 ...

  9. 安装及XShell软件的配置

    Linux系统centOS7在虚拟机下的安装及XShell软件的配置   前面的话 本文将详细介绍Linux系统centOS7在虚拟机下的安装 准备工作 [系统下载] 在安装centOS7之前,首先在 ...

  10. ARM+linux学习过程(2)安装vmware-tool过程与错误解决

    安装: 点击Ubuntu VMware菜单的-VM-Install VMware Tools 这时,在Ubuntu下会自动加载Linux版的VMware Tools的安装光盘镜像.你会看到虚拟机的桌面 ...