php之无限极分类
首先建立分类信息表:
- CREATE TABLE IF NOT EXISTS `category` (
- `categoryId` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
- `parentId` smallint(5) unsigned NOT NULL DEFAULT '0',
- `categoryName` varchar(50) NOT NULL,
- PRIMARY KEY (`categoryId`)
- ) ;
插入若干数据:
- INSERT INTO `category` (`categoryId`, `parentId`, `categoryName`) VALUES
- (1, 0, 'php'),
- (2, 0, 'java'),
- (3, 0, 'c/c++'),
- (4, 1, 'php基础'),
- (5, 1, 'php开源资料'),
- (6, 1, 'php框架'),
- (7, 2, 'java Se'),
- (8, 2, 'java EE'),
- (9, 2, 'java Me'),
- (10, 3, 'c/c++基础编程'),
- (11, 3, 'c/c++系统开发'),
- (12, 3, 'c嵌入式编程'),
- (13, 3, 'c++应用开发'),
- (14, 13, 'c++桌面应用开发'),
- (15, 13, 'c++游戏开发');
下面是php代码:
- <?php
- /*
- php无限极分类
- */
- //获取某分类的直接子分类
- function getSons($categorys,$catId=0){
- $sons=array();
- foreach($categorys as $item){
- if($item['parentId']==$catId)
- $sons[]=$item;
- }
- return $sons;
- }
- //获取某个分类的所有子分类
- function getSubs($categorys,$catId=0,$level=1){
- $subs=array();
- foreach($categorys as $item){
- if($item['parentId']==$catId){
- $item['level']=$level;
- $subs[]=$item;
- $subs=array_merge($subs,getSubs($categorys,$item['categoryId'],$level+1));
- }
- }
- return $subs;
- }
- //获取某个分类的所有父分类
- //方法一,递归
- function getParents($categorys,$catId){
- $tree=array();
- foreach($categorys as $item){
- if($item['categoryId']==$catId){
- if($item['parentId']>0)
- $tree=array_merge($tree,getParents($categorys,$item['parentId']));
- $tree[]=$item;
- break;
- }
- }
- return $tree;
- }
- //方法二,迭代
- function getParents2($categorys,$catId){
- $tree=array();
- while($catId != 0){
- foreach($categorys as $item){
- if($item['categoryId']==$catId){
- $tree[]=$item;
- $catId=$item['parentId'];
- break;
- }
- }
- }
- return $tree;
- }
- //测试 部分
- $pdo=new PDO('mysql:host=localhost;dbname=test','root','8888');
- $stmt=$pdo->query("select * from category order by categoryId");
- $categorys=$stmt->fetchAll(PDO::FETCH_ASSOC);
- $result=getSons($categorys,1);
- foreach($result as $item)
- echo $item['categoryName'].'<br>';
- echo '<hr>';
- $result=getSubs($categorys,0);
- foreach($result as $item)
- echo str_repeat(' ',$item['level']).$item['categoryName'].'<br>';
- echo '<hr>';
- $result=getParents($categorys,7);
- foreach($result as $item)
- echo $item['categoryName'].' >> ';
- echo '<hr>';
- $result=getParents2($categorys,15);
- foreach($result as $item)
- echo $item['categoryName'].' >> ';
- ?>
下面是运行的结果:
文章来源:http://blog.csdn.net/kankan231/article/details/8462349
php之无限极分类的更多相关文章
- php无限极分类以及递归(thinkphp)
php无限极分类: 无限极分类重点在于表的设计: 1在model中: class CatModel extends Model{ protected $cat = array(); public fu ...
- js实现无限极分类
转载注明出处!!! 转载注明出处!!! 转载注明出处!!! 因为要实现部门通讯录,后台传来的数据是直接从数据库里拿的部门表,所以没有层级分类,只有parentId表示从属关系,所以分类的事情就交给我来 ...
- C#无限极分类树-创建-排序-读取 用Asp.Net Core+EF实现之方法二:加入缓存机制
在上一篇文章中我用递归方法实现了管理菜单,在上一节我也提到要考虑用缓存,也算是学习一下.Net Core的缓存机制. 关于.Net Core的缓存,官方有三种实现: 1.In Memory Cachi ...
- PHP无限极分类
当你学习php无限极分类的时候,大家都觉得一个字“难”我也觉得很难,所以,现在都还在看,因为工作要用到,所以,就必须得研究研究. 到网上一搜php无限极分类,很多,但好多都是一个,并且,写的很乱, ...
- PHP无限极分类,多种方法|很简单,这里说的很详细,其它地方说的很不好懂
当你学习php无限极分类的时候,大家都觉得一个字"难"我也觉得很难,所以,现在都还在看,因为工作要用到,所以,就必须得研究研究. 到网上一搜php无限极分类,很多,但好多都是一 ...
- C#无限极分类树-创建-排序-读取 用Asp.Net Core+EF实现
今天做一个管理后台菜单,想着要用无限极分类,记得园子里还是什么地方见过这种写法,可今天找了半天也没找到,没办法静下心来自己写了: 首先创建节点类(我给它取名:AdminUserTree): /// & ...
- 谈一次php无限极分类的案例
作者:白狼 出处:http://www.manks.top/php_tree_deep.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追 ...
- PHP无限极分类生成树方法,无限分级
你还在用浪费时间又浪费内存的递归遍历无限极分类吗,看了该篇文章,我觉得你应该换换了.这是我在OSChina上看到的一段非常精简的PHP无限极分类生成树方法,巧在引用,整理分享了. function g ...
- PHP无限极分类实现
简单版的PHP生成无限极分类代码.其中包括了数据库设计.以及输出分类HTML代码. SQL代码 CREATE TABLE `district` ( `id` int(10) unsigned NOT ...
随机推荐
- JavaScript高级应用(二)(转)
1.组件是否安装 //组件是否安装 isComponentInstalled("{6B053A4B-A7EC-4D3D-4567-B8FF8A1A5739}", "com ...
- Mysql常用数据类型
Mysql常用数据类型 数字: 字符串: 时间:
- CentOS7 基础配置
Centos 7 部分>>>>>>>>>>>>>>>>>>>>>>& ...
- 快速排序(python版)
#!coding:utf8 def quicksort(list_num, left, right): if left > right: return low = left high = rig ...
- 《BI那点儿事》数据流转换——派生列
派生列转换通过对转换输入列应用表达式来创建新列值. 表达式可以包含来自转换输入的变量.函数.运算符和列的任意组合. 结果可作为新列添加,也可作为替换值插入到现有列. 派生列转换可定义多个派生列,任何变 ...
- Jqplot 使用总结之一(线条及节点颜色)
好不容易抽出时间将Jqplot做下最后的总结,下面通过四个例子来学习Jqplot的一些常见技巧:示例1. 设置线条颜色(包括背景色及线条颜色的批量赋值) <!DOCTYPE html> & ...
- canvas滤镜之简单的取反
自己学习了一下canvas滤镜 编写一个简单的小界面,嘿嘿! 注释都在里面啦啦啦,感兴趣的来瞅瞅哦
- mysql 关键字于数据库字段于关键字冲突的问题
如果数据库存储字段 为MySQL关键字,那么在查询或者其他操作时会出错.那么我们应该怎么办, 可能有些人会说,换个字段不就好了啊.当然这样也是可以的,完全没问题. 然而,如果是在无法对数据库进行修改和 ...
- mousedown(function(){ return false; })作用
mousedown(function(){ return false;}); 阻止浏览器的默认行为. 比如a你加个空连接,可能会在当前页跳转, 你加了这句,就可以阻止a跳转,然后只执行js函数的代 ...
- PHP的三种输出方式
(1)echo 是PHP语句,没有返回值,用于输出一个或多个字符串 (2)print() 是函数,可以有返回值,只能打印出简单类型变量的值,例如int.string (3)print_r() 是函数, ...