ThinkPhp 实现 无限极分类及树状结构 附加使用例子

PS: 最下方有PHP文字,直接copy使用

FOR examle: 例子

        $list = Db::name('user')->field('name,id,pid')->select();
        $array =Category::toLayer($list);

结果

ThinkPhp 实现 无限极分类及树状结构 附加使用例子_第1张图片
image.png

Php 代码文件

class Category {

    //一维数组
    static public function toLevel($cate, $delimiter = '———', $parent_id = 0, $level = 0) {

        $arr = array();
        foreach ($cate as $v) {
            if ($v['parent_id'] == $parent_id) {
                $v['level'] = $level + 1;
                $v['delimiter'] = str_repeat($delimiter, $level);
                $arr[] = $v;
                $arr = array_merge($arr, self::toLevel($cate, $delimiter, $v['id'], $v['level']));
            }
        }

        return $arr;

    }

    /**
     * 组成多维数组
     * @param $cate  将要被转换为树形的
     * @param string $name 子节点名字 默认 child
     * @param int $pid 父类ID, 第一级的 pid 默认为0,根据情况自己更改
     * @return array
     */
    static public function toLayer($cate, $name = 'child', $pid = 0){

        $arr = array();
        foreach ($cate as $v) {
            if ($v['pid'] == $pid) {
                $v[$name] = self::toLayer($cate, $name, $v['id']);
                $arr[] = $v;
            }
        }

        return $arr;
    }


    //一维数组(同模型)(model = tablename相同),删除其他模型的分类
    static public function getLevelOfModel($cate, $tablename = 'article') {

        $arr = array();
        foreach ($cate as $v) {
            if ($v['tablename'] == $tablename) {
                $arr[] = $v;
            }
        }

        return $arr;

    }

    //一维数组(同模型)(modelid),删除其他模型的分类
    static public function getLevelOfModelId($cate, $modelid = 0) {

        $arr = array();
        foreach ($cate as $v) {
            if ($v['modelid'] == $modelid) {
                $arr[] = $v;
            }
        }

        return $arr;

    }

    //传递一个子分类ID返回他的所有父级分类
    static public function getParents($cate, $id) {
        $arr = array();
        foreach ($cate as $v) {
            if ($v['id'] == $id) {
                $arr[] = $v;
                $arr = array_merge(self::getParents($cate, $v['pid']), $arr);
            }
        }
        return $arr;
    }

    //传递一个子分类ID返回他的同级分类
    static public function getSameCate($cate, $id) {
        $arr = array();
        $self = self::getSelf($cate, $id);
        if (empty($self)) {
            return $arr;
        }

        foreach ($cate as $v) {
            if ($v['id'] == $self['pid']) {
                $arr[] = $v;
            }
        }
        return $arr;
    }



    //判断分类是否有子分类,返回false,true
    static public function hasChild($cate, $id) {
        $arr = false;
        foreach ($cate as $v) {
            if ($v['pid'] == $id) {
                $arr = true;
                return $arr;
            }
        }

        return $arr;
    }

    //传递一个父级分类ID返回所有子分类ID
    /**
     *@param $cate 全部分类数组
     *@param $pid 父级ID
     *@param $flag 是否包括父级自己的ID,默认不包括
     **/
    static public function getChildsId($cate, $pid, $flag = 0) {
        $arr = array();
        if ($flag) {
            $arr[] = $pid;
        }
        foreach ($cate as $v) {
            if ($v['pid'] == $pid) {
                $arr[] = $v['id'];
                $arr = array_merge($arr , self::getChildsId($cate, $v['id']));
            }
        }

        return $arr;
    }


    //传递一个父级分类ID返回所有子级分类
    static public function getChilds($cate, $pid) {
        $arr = array();
        foreach ($cate as $v) {
            if ($v['pid'] == $pid) {
                $arr[] = $v;
                $arr = array_merge($arr, self::getChilds($cate, $v['id']));
            }
        }
        return $arr;
    }

    //传递一个分类ID返回该分类相当信息
    static public function getSelf($cate, $id) {
        $arr = array();
        foreach ($cate as $v) {
            if ($v['id'] == $id) {
                $arr = $v;
                return $arr;
            }
        }
        return $arr;
    }

    //传递一个分类ID返回该分类相当信息
    static public function getSelfByEName($cate, $ename) {
        $arr = array();
        foreach ($cate as $v) {
            if ($v['ename'] == $ename) {
                $arr = $v;
                return $arr;
            }
        }
        return $arr;
    }

}

你可能感兴趣的:(ThinkPhp 实现 无限极分类及树状结构 附加使用例子)