概述
推荐:《PHP视频教程》
public function index()
{
$data = [
[
'id'=>1,
'parent_id' => 0,
'name' => '第一个'
],
[
'id'=>2,
'parent_id' => 0,
'name' => '第二个'
],
[
'id'=>3,
'parent_id' => 1,
'name' => '第三个'
],
];
$r = $this->list_to_tree($data);
dump($r);
}
登录后复制
#数组转树结构#
function list_to_tree($list, $root = 0, $pk = 'id', $pid = 'parent_id', $child = 'children'){
// 创建Tree
$tree = array();
if (is_array($list)) {
// 创建基于主键的数组引用
$refer = array();
foreach ($list as $key => $data) {
$refer[$data[$pk]] = &$list[$key];
}
foreach ($list as $key => $data) {
// 判断是否存在parent
$parentId = 0;
if (isset($data[$pid])) {
$parentId = $data[$pid];
}
if ((string)$root == $parentId) {
$tree[] = &$list[$key];
} else {
if (isset($refer[$parentId])) {
$parent = &$refer[$parentId];
$parent[$child][] = &$list[$key];
}
}
}
}
return $tree;}
登录后复制
#树结构转数组#
function tree_to_list($tree = [], $children = 'children'){
if (empty($tree) || !is_array($tree)) {
return $tree;
}
$arrRes = [];
foreach ($tree as $k => $v) {
$arrTmp = $v;
unset($arrTmp[$children]);
$arrRes[] = $arrTmp;
if (!empty($v[$children])) {
$arrTmp = tree_to_list($v[$children]);
$arrRes = array_merge($arrRes, $arrTmp);
}
}
return $arrRes;}
登录后复制
以上就是PHP数组转树结构以及树结构转数组的详细内容,更多请关注靠谱客其它相关文章!
最后
以上就是淡定灰狼为你收集整理的PHP数组转树结构以及树结构转数组的全部内容,希望文章能够帮你解决PHP数组转树结构以及树结构转数组所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复