承接 lambert/tree-shape 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

lambert/tree-shape

最新稳定版本:1.0.0

Composer 安装命令:

composer require lambert/tree-shape

包简介

A simple way to generate a tree structure.

README 文档

README

生成树形结构的简单方式

Feature

有Relation_key的关系数据,都可以生成树状的结构

Install

$ composer require lambert/tree-shape

RequireMent

  • PHP >= 5.6

Usage

use Lambert\TreeShape\Manager;
 
$category = [
    ['id' => 1, 'name' => '节点1', 'pid' => 0],
    ['id' => 2, 'name' => '节点2', 'pid' => 0],
    ['id' => 3, 'name' => '节点3', 'pid' => 1],
    ['id' => 4, 'name' => '节点4', 'pid' => 1],
];
 
// Start build
$manager = Manager::buildTree($category, 'pid');
$tree = $manager->all();

生成后:

Array
(
    [1] => Lambert\TreeShape\Tree Object
        (
            [childrenIds:protected] => Array
                (
                    [0] => 3
                    [1] => 4
                )

            [recursionChildrenIds:protected] =>
            [currentNode:protected] => Lambert\TreeShape\Node Object
                (
                    [data:protected] => Array
                        (
                            [id] => 1
                            [name] => 节点1
                            [pid] => 0
                        )

                )

            [leftTree:protected] =>
            [rightTree:protected] => Array
                (
                    [3] => Lambert\TreeShape\Tree Object
                        (
                            [childrenIds:protected] =>
                            [recursionChildrenIds:protected] =>
                            [currentNode:protected] => Lambert\TreeShape\Node Object
                                (
                                    [data:protected] => Array
                                        (
                                            [id] => 3
                                            [name] => 节点3
                                            [pid] => 1
                                        )

                                )

                            [leftTree:protected] => Lambert\TreeShape\Tree Object
 *RECURSION*
                            [rightTree:protected] =>
                        )

                    [4] => Lambert\TreeShape\Tree Object
                        (
                            [childrenIds:protected] =>
                            [recursionChildrenIds:protected] =>
                            [currentNode:protected] => Lambert\TreeShape\Node Object
                                (
                                    [data:protected] => Array
                                        (
                                            [id] => 4
                                            [name] => 节点4
                                            [pid] => 1
                                        )

                                )

                            [leftTree:protected] => Lambert\TreeShape\Tree Object
 *RECURSION*
                            [rightTree:protected] =>
                        )

                )

        )

    [2] => Lambert\TreeShape\Tree Object
        (
            [childrenIds:protected] =>
            [recursionChildrenIds:protected] =>
            [currentNode:protected] => Lambert\TreeShape\Node Object
                (
                    [data:protected] => Array
                        (
                            [id] => 2
                            [name] => 节点2
                            [pid] => 0
                        )

                )

            [leftTree:protected] =>
            [rightTree:protected] =>
        )

)

Methods

  • 查找某个Tree
$tree = $manager->findTree('name', '子节点1');
 
Lambert\TreeShape\Tree Object
(
    [childrenIds:protected] => Array
        (
            [0] => 3
            [1] => 4
        )

    [recursionChildrenIds:protected] =>
    [currentNode:protected] => Lambert\TreeShape\Node Object
        (
            [data:protected] => Array
                (
                    [id] => 1
                    [name] => 节点1
                    [pid] => 0
                )

        )

    [leftTree:protected] =>
    [rightTree:protected] => Array
        (
            [3] => Lambert\TreeShape\Tree Object
                (
                    [childrenIds:protected] =>
                    [recursionChildrenIds:protected] =>
                    [currentNode:protected] => Lambert\TreeShape\Node Object
                        (
                            [data:protected] => Array
                                (
                                    [id] => 3
                                    [name] => 节点3
                                    [pid] => 1
                                )

                        )

                    [leftTree:protected] => Lambert\TreeShape\Tree Object
*RECURSION*
                    [rightTree:protected] =>
                )

            [4] => Lambert\TreeShape\Tree Object
                (
                    [childrenIds:protected] =>
                    [recursionChildrenIds:protected] =>
                    [currentNode:protected] => Lambert\TreeShape\Node Object
                        (
                            [data:protected] => Array
                                (
                                    [id] => 4
                                    [name] => 节点4
                                    [pid] => 1
                                )

                        )

                    [leftTree:protected] => Lambert\TreeShape\Tree Object
*RECURSION*
                    [rightTree:protected] =>
                )

        )

)
  • 获取当前树的左、右子树
$leftTree = $tree->getLeftTree();
$rightTree = $tree->getRightTree();
Lambert\TreeShape\Tree Object
(
    [childrenIds:protected] => Array
        (
            [0] => 3
            [1] => 4
        )

    [recursionChildrenIds:protected] =>
    [currentNode:protected] => Lambert\TreeShape\Node Object
        (
            [data:protected] => Array
                (
                    [id] => 1
                    [name] => 节点1
                    [pid] => 0
                )

        )

    [leftTree:protected] =>
    [rightTree:protected] =>
)

**注意:获取右子树时,根据自己数据类型的关系,多个右子树的话,会返回Array**
  • 获取节点属性
继承了SPL的ArrayAccess,可以使用数组或属性的方式访问
 
$node = $tree->getCurrentNode();
 
$node['name'] or $node->name;   // 节点1
 
$node['id'] or $node->id;   // 1
...

License

MIT

统计信息

  • 总下载量: 5.57k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 19
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 18
  • Watchers: 1
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-01-10