php中分层数据转树结构(数据不去重)并且带有level层级

前言

在项目开发的过程中有时候需要对数据进行数据转换,这里介绍一种对层级数据转换为树结构数据并且不对重复数据进行去重,并且带有level层级字段。
代码如下:

if (!function_exists('prepare_level_tree')) {
    /**
     * 分层数据转树结构(不去重)并且带有level
     * @param [type] $data 列表数据
     * @param string $child 子级
     * @param integer $pid 父级id
     * @param integer $level 层级
     */
    function prepare_level_tree(array $data, string $child = 'children', int $pid = 0, int $level = 0)
    {
        $tree = array();
        $level = $level + 1;
        foreach ($data as $v) {
            if ($v['pid'] == $pid) {
                $v['level'] = $level;
                $children = prepare_level_tree($data, $child, $v['id'], $level);
                if ($children) {
                    $v[$child] = $children;
                }
                $tree[] = $v;
            }
        }
        return $tree;
    }
}

使用方法直接进行调用即可,id和pid表示父子级关系。

你可能感兴趣的:(php,thinkphp,算法,php,开发语言,后端)