###
这两天脑壳痛,一时短路,想不到准备利用递归实现这个需求,最后还是要请教同事,回来自己在实现了一遍,并记录下来
###
原数据:
// {
// 广东省: {
// 广州市: [
// "天河区",
// "从化区",
// "增城区"
// ],
// 深圳市: [
// "南山区",
// "福田区",
// "宝安区"
// ]
// },
// 吉林省: {
// 长春市: [
// "朝阳区"
// ]
// }
// }
需实现的树结构格式:
[{
value: "广东省",
children: [{
value: "广州市",
children: [{
value: "天河区"
},{
value: "从化区"
},{
value: "增城区"
}]
},{
value: "深圳市",
children: [{
value: "南山区"
},{
value: "福田区"
},{
value: "宝安区"
}]
}]
},{
value: "吉林省",
children: [{
value: "长春市",
children: [{
value: "朝阳区"
}]
}]
}]
实现过程:
1.实现一个获取多维数据层数的函数
// 递归获取数组结构的层数
function get_array_level($arr) { $level = 1;
if (is_array($arr)) {
foreach ($arr as $key => $value) { if (!empty($value)) {
$level += 1;
get_array_level($value);
}
}
} return $level;
、
}
2.进行树结构的组装
//转为指定树状结构
function get_array_tree($arr) {
$res_arr = array();
// 获取数组的层次
$level = get_array_level($arr);
if ($level > 1) {
foreach ($arr as $key => $value) {
if (is_array($value)) { $res_arr[] = array(
'value' => $key,
'children' => get_array_tree($value) // 递归返回遍历数据的子数组
);
} else {
$res_arr[] = array(
'value' => $value,
);
} } } return $res_arr; }
打印数组
$arr = get_array_tree($arr);
echo json_encode($arr);die;
效果