php 分类排序,php无限分类树[支持子分类排序]

没有人规定一定要使用类,你写成一个函数也可以,每个人的编程习惯、风格、喜好都不一样,关于封装成类是为了使这段程序具有结构条理性,而不是随意放置,关于类中包含的多个方法(vTree、hTree)主要应对不同业务场景,vTree为单线纵向结构,而hTree为树形结构。

ClassTree.class.php<?php

/**

* 无限分类树(支持子分类排序)

* version:1.4

* author:Veris

* website:www.mostclan.com

*/

class ClassTree {

/**

* 分类排序(降序)

*/

static public function sort($arr,$cols){

//子分类排序

foreach ($arr as $k => &$v) {

if(!empty($v['sub'])){

$v['sub']=self::sort($v['sub'],$cols);

}

$sort[$k]=$v[$cols];

}

if(isset($sort))

array_multisort($sort,SORT_DESC,$arr);

return $arr;

}

/**

* 横向分类树

*/

static public function hTree($arr,$pid=0){

foreach($arr as $k => $v){

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

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

$data[$v['id']]['sub']=self::hTree($arr,$v['id']);

}

}

return isset($data)?$data:array();

}

/**

* 纵向分类树

*/

static public function vTree($arr,$pid=0){

foreach($arr as $k => $v){

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

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

$data+=self::vTree($arr,$v['id']);

}

}

return isset($data)?$data:array();

}

}

返回例子:Array

(

[4] => Array

(

[id] => 4

[pid] => 0

[name] => 上海

[sort] => 2

)

[5] => Array

(

[id] => 5

[pid] => 4

[name] => 闵行

[sort] => 0

)

[1] => Array

(

[id] => 1

[pid] => 0

[name] => 浙江

[sort] => 0

)

[13] => Array

(

[id] => 13

[pid] => 1

[name] => 金华

[sort] => 1

)

[10] => Array

(

[id] => 10

[pid] => 1

[name] => 宁波

[sort] => 0

)

[6] => Array

(

[id] => 6

[pid] => 10

[name] => 宁海

[sort] => 0

)

)

Array

(

[4] => Array

(

[id] => 4

[pid] => 0

[name] => 上海

[sort] => 2

[sub] => Array

(

[5] => Array

(

[id] => 5

[pid] => 4

[name] => 闵行

[sort] => 0

[sub] => Array

(

)

)

)

)

[1] => Array

(

[id] => 1

[pid] => 0

[name] => 浙江

[sort] => 0

[sub] => Array

(

[13] => Array

(

[id] => 13

[pid] => 1

[name] => 金华

[sort] => 1

[sub] => Array

(

)

)

[10] => Array

(

[id] => 10

[pid] => 1

[name] => 宁波

[sort] => 0

[sub] => Array

(

[6] => Array

(

[id] => 6

[pid] => 10

[name] => 宁海

[sort] => 0

[sub] => Array

(

)

)

)

)

)

)

)public function vTree($arr,$pid=0){

foreach($arr as $k => $v){

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

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

$data+=vTree($arr,$v['id']);

}

}

return isset($data)?$data:array();

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值