php 无限级分类示例代码


本文摘自PHP中文网,作者怪我咯,侵删。

这里首先介绍一下,什么是无限极分类?

无限极分类简单点说就是一个类可以分成多个子类,然后一个子类又可以分另外多个子类这样无限分下去,就好象windows可以新建一个文件夹,然后在这个文件夹里又可以建一些个文件夹,在文件夹底下还可以建一些文件夹一样

那php又是如何实现它的无限分类的呢?如何把它的各个分类一一列出来呢?代码如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

<?php

/**

 * 无限级分类 类

 */

class Category{

 /**

  * 返回一维数组

  * @param [type] $cate 要递归的数组

  * @param string $html 子级分类前要显示的缩进符号。默认 '─'

  * @param integer $pid 父级分类ID。默认为 0,表示顶级分类

  * @param integer $level level级,配合 $html 显示足够的缩进。默认为 1,表示顶级分类

  * @return [type]   [description]

  */

 static public function unlimitedForLevel($cate, $html = '─', $pid = 0, $level = 1){

  $arr = array();

  foreach($cate as $v){

   if($v['pid'] == $pid){

    $v['level'] = $level;

    $v['html'] = str_repeat($html, $level - 1);

    $arr[] = $v;

    $arr = array_merge($arr, $this->unlimitedForLevel($cate, $html, $v['id'], $level + 1));

   }

  }

  return $arr;

 }

 /**

  * 返回多维数组

  * @param [type] $cate 要递归的数组

  * @param string $name 子级分类在父分类数组中的 key

  * @param integer $pid 父级分类ID。默认为0,表示顶级分类

  * @return [type]  [description]

  */

 static public function unlimitedForlayer($cate, $name = 'child', $pid = 0){

  $arr = array();

  foreach($cate as $v){

   if( $v['pid'] == $pid){

    $v[$name] = self::unlimitedForlayer($cate, $name, $v['id']);

    $arr[] = $v;

   }

  }

  return $arr;

 }

 /**

  * 传递子分类ID返回所有父级分类

  * @param [type] $cate 要递归的数组

  * @param [type] $id 子分类ID

  * @return [type]  [description]

  */

 static public function getParents($cate, $id){

  $arr = array();

  foreach($cate as $v){

   if($v['id'] == $id){

    $arr[] = $v;

    $arr = array_merge(self::getParents($cate, $v['pid']), $arr);

   }

  }

  return $arr;

 }

 /**

  * 传递父级分类ID返回所有子分类ID

  * @param [type] $cate 要递归的数组

  * @param [type] $pid 父级分类ID

  * @return [type]  [description]

  */

 static public function getChildrenId($cate, $pid){

  $arr = array();

  foreach($cate as $v){

   if($v['pid'] == $pid){

    $arr[] = $v['id'];

    $arr = array_merge($arr, self::getChildrenId($cate, $v['id']));

   }

  }

  return $arr;

 }

 /**

  * 传递父级分类ID返回所有子级分类

  * @param [type] $cate 要递归的数组

  * @param [type] $pid 父级分类ID

  * @return [type]  [description]

  */

 static public function getChildren($cate, $pid){

  $arr = array();

  foreach($cate as $v){

   if($v['pid'] == $pid){

    $arr[] = $v;

    $arr = array_merge($arr, self::getChildren($cate, $v['id']));

   }

  }

  return $arr;

 }

}

?>

以上就是php 无限级分类示例代码的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

PHP mysql如何查询数据

PHP实现守护进程的两种常见方式

redis实现秒杀的方法介绍(附代码)

详细介绍消息队列的概念、原理及使用场景(附案例)

yaf的安装_配置yaf的rewrite规则_生成一个最简单的yaf项目

PHP 读取rss feed的代码示例

PHP优化数据库的方法

PHP限制ip地址范围的实现方法

25行实现mysql树查询代码详解

提高工作效率:mysql的优化技巧

更多相关阅读请进入《PHP》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...