PHP利用递归函数实现无限级分类的方法_php技巧 - PHP

文章来源:嗨学网 敏而好学论坛www.piaodoo.com 欢迎大家相互学习

相信很多学php的很多小伙伴都会尝试做一个网上商城作为提升自己技术的一种途径。各种对商品分类,商品名之类的操作应该是得心应手,那么就可以尝试下无限级分类列表的制作了。

什么是无限级分类?

无限级分类是一种分类技巧,例如部门组织,文章分类,学科分类等常用到无限级分类,将其简单理解成分类就好了。其实我们仔细想一下,生活中的分类简直太多了,衣服可以分为男装和女装,也可以分为上衣和裤子,也可以根据年龄段分类。分类无处不在,分类显得“无限”。我这里就不说无限分类的必要性了。

无限级分类原理简介

无限分类看似"高大上",实际上原理是非常简单的 。无限分类不仅仅需要代码的巧妙性,也要依托数据库设计的合理性。要满足无限级分类,数据库需要有两个必须的字段,id,pid。id用来标识自身,而pid则是用来表明父级id。也就是说,每个分类记录不仅描述了自身,还描述了与其关心最为紧密的另一个id。看似复杂的事情被这样一个小技巧解决了。

php无限级分类是经常要用到的,本人以前一直用的是已经写好的,所以没仔细去研究过,下面是一个使用递归实现的简单的php无限级分类的函数;也许这不是最优的方法,但对于一般的应用也足够了。

数据表结构

CREATE TABLE IF NOT EXISTS `category` (
 `id` int(5) NOT NULL AUTO_INCREMENT COMMENT ‘唯一自增id‘,
 `pid` int(5) NOT NULL DEFAULT ‘0‘ COMMENT ‘父id‘,
 `sort` int(2) NOT NULL DEFAULT ‘0‘ COMMENT ‘排序数字‘,
 `name` varchar(30) DEFAULT NULL COMMENT ‘名称‘,
 PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT=‘无限极分类表‘ AUTO_INCREMENT=1 ;

数据

INSERT INTO `category` (`id`, `pid`, `sort`, `name`) VALUES
(1, 0, 1, ‘php‘),
(2, 0, 2, ‘数据库‘),
(3, 0, 3, ‘javascript‘),
(4, 1, 1, ‘框架模板‘),
(5, 1, 2, ‘函数总结‘),
(6, 2, 1, ‘mysql‘),
(7, 4, 1, ‘框架‘),
(8, 4, 2, ‘模板‘),
(9, 8, 1, ‘smarty‘),
(10, 7, 2, ‘thinkphp‘),
(11, 10, 1, ‘thinkphp技巧‘),
(12, 10, 2, ‘thinkphp模板‘),
(13, 12, 3, ‘模板知识总结‘),
(14, 12, 2, ‘模板视频教程‘),
(15, 11, 1, ‘model技巧‘);

函数实现代码

function tree(&$list,$pid=0,$level=0,$html=‘--‘){
  static $tree=array();
  foreach($list as $v){
    if($v[‘pid‘]==$pid){
      $v[‘level‘]=$level;
      $v[‘html‘]=str_repeat($html,$level);
      $tree[]=$v;
      tree($list,$v[‘id‘],$level+1,$html);
    }
  }
  return $tree;
}

以上tree函数的第一个参数$list就是获取的如上表的一个二维数组的结果集。需要注意的是从数据库获取结果集的sql语句必须加上order by sort asc,否则sort字段将不能发挥排序的作用。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对敏而好学论坛/嗨学网的支持。如果你想了解更多相关内容请查看下面相关链接

原文地址是:http://www.piaodoo.com/thread-3556-1-1.html

原文地址:https://www.cnblogs.com/txdah/p/12093152.html

时间: 2024-10-14 13:35:11

PHP利用递归函数实现无限级分类的方法_php技巧 - PHP的相关文章

php利用递归函数实现无限级分类

相信很多学php的很多小伙伴都会尝试做一个网上商城作为提升自己技术的一种途径.各种对商品分类,商品名之类的操作应该是得心应手,那么就可以尝试下无限级分类列表的制作了. 什么是无限级分类? 无限级分类是一种分类技巧,例如部门组织,文章分类,学科分类等常用到无限级分类,将其简单理解成分类就好了.其实我们仔细想一下,生活中的分类简直太多了,衣服可以分为男装和女装,也可以分为上衣和裤子,也可以根据年龄段分类.分类无处不在,分类显得“无限”.我这里就不说无限分类的必要性了. 无限级分类原理简介 无限分类看

php下利用递归实现无限级分类

<?php //分析 /* 福建省 福州市 龙岩市 广东省 广州市 佛山市 晋江市 江门市 江西省 南昌市 赣州市 宁都县 大余县 信封县 吉安市 cat_id pri parent_id 1 福建省 0 2 福州市 1 3 龙岩市 1 4 广东省 0 5 广州市 4 6 佛山市 4 7 晋江市 4 8 江门市 7 9 江西省 0 10 南昌市 9 11 赣州市 9 12 宁都县 11 13 大余县 11 14 信封县 11 15 吉安市 9 16 */ ?> <?php header(

无限级分类数据处理方法

/** * 把返回的数据集转换成Tree * @param array $list 要转换的数据集 * @param string $pid parent标记字段 * @param string $level level标记字段 * @return array * @author 麦当苗儿 <[email protected]> */ function list_to_tree($list, $pk='id', $pid = 'pid', $child = '_child', $root =

PHP应用跨时区功能的实现方法_php技巧 - PHP

文章来源:嗨学网 敏而好学论坛www.piaodoo.com 欢迎大家相互学习 PHP中要实现一个跨时区的应用,也就是不同时区登录的用户需要看到自己时区的时间,同时也要能够进行时区的切换. 这里的思路是,系统中所有存储的时间都是GMT(UTC)时间,用户登录时,根据用户所在的时区进行对应的显示. 关于PHP中时间函数的使用就参考:PHP时间函数使用详解.这里我们先了解一下PHP中时区的设置方法.PHP中进行设置的方法比较灵活多样,可以在php.ini中设置date.timezone属性.可以通过

mysql无限级分类实现基于汇报关系的信息管理权限

汇报关系和家族族谱的实现类似,采用树的数据结构进行定义,树采用递归进行定义.即要嘛是一个根节点,要嘛是由一个根节点和其子树组成.OA中的汇报关系也采用这种结构(与树稍有不同),除董事长外,其他人有且只有一个非其本人的直接主管,董事长的直接主管和越级主管是其本人.从以上的定义其实可以看出,汇报关系类似树,但又与树并不完全相同.除董事长外,其他汇报关系均是树形结构.树形结构采用递归定义,如采用递归查询是非常耗时的操作.比如以下需求: 1.主管可以看到所有直线下属的绩效信息: 针对以上需求,我们提出三

Laravel 5.4 实现无限级分类

最近在工作中遇到一个需求,是要在laravel 5.4中实现无限级分类,但发现网上这个的资料较少,所以只能自己来实现了,下面这篇文章主要给大家介绍了关于在laravel 5.4中实现无限级分类的方法示例,需要的朋友可以参考借鉴,下面来一起看看吧. 前言 本文主要给大家介绍的是关于laravel 5.4中实现无限级分类的相关内容,分享出来供有需要的朋友们参考学习,下面话不多说,来一起看看详细的介绍吧. 方法如下: 1.建立表 ? 1 php artisan make:migration creat

MyBatis无限级分类实现的两种方法--自关联与map集合

1.这回先创建数据库吧 下表cid是CategoryId的缩写,cname是CategoryName的缩写,pid是parentId的缩写 无限级分类一般都包含这三个属性,至少也要包含cid和pid才能建立无限级关联 ok,这个东东就是无限级分类了. 即便是外行人稍微看一眼也能发现cid为1的图书在小说和周刊两行中作为了pid,也就是说小说和周刊的父级分类就是图书 图书和饮料的pid是0,代表他们是顶级分类 如果没有其他约束条件,这张表几乎可以无限向下级延伸,是一个树形结构,这里就不写什么数学公

Thinkphp的list_to_tree 实现无限级分类列出所有节点

list_to_tree 使用起来十分方便,详细可查看手册.因为我在用的时候需要同时列出所有节点,所以写了一个递归函数,拿出来供大家参考. public function index(){ Load('extend'); //加载扩展方法 $Category=D('Category'); $list=$Category->order('sort desc')->select();//实现同级节点排序 $list=list_to_tree($list,'id','fid'); //详细参数见手册

用迭代实现无限级分类

说起那个无限级分类,相信很多人都知道是什么东西,也曾经做过.我也相信,大家用得最多的实现方式就是做一个递归. 最近我也要做一个带无限级分类的菜单,但是我又不想用递归来做,所以我需要用其他方式来实现,那就是迭代了. 首先,我需要定义一个实体模型,这举一个省市无限级的例子: class Loaction { public int ID { get; set; } public int PID { get; set; } public string Name { get; set; } //地方名 p