php树状

$data = [
    ['self' => 'd', 'parent' => 'c'],
    ['self' => 'b', 'parent' => 'a'],
    ['self' => 'c', 'parent' => 'b'],
    ['self' => 'e', 'parent' => 'a'],
    ['self' => 'a', 'parent' => null],
    ['self' => 'f', 'parent' => 'e'],
    ['self' => 'h', 'parent' => 'g'],
    ['self' => 'g', 'parent' => 'f'],
    ['self' => 'h', 'parent' => null],
    ['self' => 'i', 'parent' => 'h'],
    ['self' => 'j', 'parent' => 'g'],
];
/**
 * @param $data 节点
 * @param $parent 父节点
 * @param string $keySelf 标识字符串
 * @param string $keyParent 父节点标识字符串
 * @param string $keyChild 子节点标识字符串
 * @param null $null 空父节点标识字符串
 * @return mixed 节点
 */
function parent($data, $parent, $keySelf = 'self', $keyParent = 'parent', $keyChild = 'child', $null = null)
{
    foreach ($data as $key => $value) {
        if ($value[$keySelf] == $parent[$keyParent]) {//查找到父级
            $data[$key][$keyChild][] = $parent;//子级加入到父级child
            return $data;
        } elseif (isset($value[$keyChild])) {//未查找到父级,节点存在子级
            $data[$key][$keyChild] = parent($value[$keyChild], $parent, $keySelf, $keyParent, $keyChild, $null);//节点的子级中查找父级
        }
    }
    return $data;
}

/**
 * @param $data 节点数组,结构中包括标识(string,唯一,必须),父节点标识(string,非必须),可包含任意其他数据
 * @param string $keySelf 标识字符串
 * @param string $keyParent 父节点标识字符串
 * @param string $keyChild 子节点标识字符串
 * @param null $null 空父节点标识字符串
 * @return mixed 树状数组
 */
function tree($data, $keySelf = 'self', $keyParent = 'parent', $keyChild = 'child', $null = null)
{
    foreach ($data as $key => $value) {
        if ($value[$keyParent] != $null) {//处理非顶级
            $data = parent($data, $value, $keySelf, $keyParent, $keyChild, $null);//查找父级
            unset($data[$key]);
        }
    }
    return $data;
}

var_dump(tree($data));
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值