将树形结构的数据转换为二维数组 (续 PHP非递归方式实现无限分类(转载))
来源:互联网 发布:淘宝网店做什么好 编辑:程序博客网 时间:2024/05/01 13:08
//将树形结构转换为普通的二维数组
function treeToArray($tree){
static $arr = [];
foreach($tree as $val){
$arr[] = ['id'=>$val['id'],'name'=>$val['name'],'pid'=>$val['pid']];
if(isset($val['son']) && !empty($val['son'])){
treeToArray($val['son']);
}
}
return $arr;
}
//列子
$list = [
1=>['id'=>1,'pid'=>0,'name'=>'服装'],
2=>['id'=>2,'pid'=>0,'name'=>'数码'],
3=>['id'=>3,'pid'=>0,'name'=>'食品'],
4=>['id'=>4,'pid'=>1,'name'=>'男装'],
5=>['id'=>5,'pid'=>1,'name'=>'女装'],
6=>['id'=>6,'pid'=>1,'name'=>'童装'],
7=>['id'=>7,'pid'=>1,'name'=>'内衣'],
8=>['id'=>8,'pid'=>2,'name'=>'平板电脑'],
9=>['id'=>9,'pid'=>2,'name'=>'摄像摄影'],
10=>['id'=>10,'pid'=>2,'name'=>'智能数码'],
11=>['id'=>11,'pid'=>2,'name'=>'娱乐影音'],
12=>['id'=>12,'pid'=>3,'name'=>'新鲜水果'],
13=>['id'=>13,'pid'=>3,'name'=>'蔬菜蛋品'],
14=>['id'=>14,'pid'=>3,'name'=>'精选肉类'],
15=>['id'=>15,'pid'=>3,'name'=>'海鲜水产'],
16=>['id'=>16,'pid'=>7,'name'=>'男士内衣'],
17=>['id'=>17,'pid'=>7,'name'=>'女生内衣'],
];
//1.转换为树形结构
$tree = tree($list);
echo '<pre>';
var_dump($tree);
echo '<hr>';
//将树形结构转换为二维数组
$t = treeToArray($tree);
var_dump($t);
- 将树形结构的数据转换为二维数组 (续 PHP非递归方式实现无限分类(转载))
- PHP非递归方式实现无限分类(转载)
- php不用递归实现无限分类数据的树形格式化
- php 实现不用递归的树形数组构造函数 无限级分类
- PHP非递归实现无限级分类
- PHP无限分类(树形类),非数据库直接递归
- php 无限分类递归树形
- php 递归 实现无限分类 格式化数组
- PHP递归实现无限分类数组处理
- 递归处理无限级分类为树形数组
- sqlserver实现树形结构递归查询(无限极分类)
- sqlserver实现树形结构递归查询(无限极分类)
- sqlserver实现树形结构递归查询(无限极分类)
- Java编程:将具有父子关系的数据库表数据转换为树形结构,支持无限层级
- PHP无限级分类实现(递归+非递归)
- PHP无限级分类实现(递归+非递归)
- PHP无限级分类实现(递归+非递归)
- PHP无限级分类实现(递归+非递归)
- 正则
- charles破解
- Objective-C 中nil Nil NULL NSNull 之间的区别
- hdu4160 Dolls【最小路径覆盖】
- Android View事件分发机制
- 将树形结构的数据转换为二维数组 (续 PHP非递归方式实现无限分类(转载))
- iOS自动打包并发布脚本
- 有返回结果的界面跳转
- 微信的分享文本,音频,视频,链接,表情,图片功能
- USB mass storage协议
- Android NDK 较完整的总结
- redis中 sCard 和 sSize 有什么区别?
- USB驱动开发之mass storage的枚举识别过程
- Eclipse中Web项目出现感叹或红叉该怎么解决?