大家通常都是使用递归实现无限极分类,都知道递归效率很低,下面推荐一个 Laravel 的扩展包 etrepat/baum,快速让你的数据模型支持无限极树状层级结构,并且兼顾效率。
扩展包的 官方文档 里有解释的篇幅,下面这张图的也是一个简单的例子:
用例说明
接下来讲几个无限树状层级模型的例子。
标签系统
参考:Laravel Taggable 为你的模型添加打标签功能
一个标签可以有无数多子标签,属于一个父标签,有多个同辈标签。
如下面的这颗标签树:
code1 2 3 4 5 6 7 8 9 10 11 12 13 14 | <code class = "php" >$tagTree = [
'name' => 'RootTag' ,
'children' => [
[ 'name' => 'L1Child1' ,
'children' => [
[ 'name' => 'L2Child1' ],
[ 'name' => 'L2Child1' ],
[ 'name' => 'L2Child1' ],
]
],
[ 'name' => 'L1Child2' ],
[ 'name' => 'L1Child3' ],
]
];</code>
|
评论系统
评论的无限极别嵌套,如网易的 跟帖系统。
Laravel 有一个评论扩展包支持无限极别嵌套,请见 Slynova-Org/laravel-commentable。
「导航栏」数据模型
管理员后台需要提供「导航栏」自定义功能,树状结构导航栏。
集成 Baum
etrepat/baum 快速让你的数据模型支持无限极树状层级结构,且兼顾效率。
接下来我们讲如何集成。
1. composer 安装
code1 | <code>composer require "baum/baum:~1.1" </code>
|
2. 增加 provider
修改 config/app.php
文件,在 providers
数组中添加:
code1 | <code class = "php" > 'Baum\Providers\BaumServiceProvider' ,</code>
|
此服务提供者注册了两个命令:artisan baum
, artisan baum.install
。
3. 创建 migration
安装到已存在的数据模型上:
code1 | <code class = "php" >php artisan baum:install MODEL</code>
|
然后执行
code1 | <code class = "php" >php artisan migrate</code>
|
关于 migration 的字段介绍
parent_id: 父节点的 id
lft: 左边索引值
rgt: 右边索引值
depth: 层级深度
下面是个例子:
code1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | <code class = "php" > class Category extends Migration
{
public function up() {
Schema::create( 'categories' , function(Blueprint $table) {
$table->increments( 'id' );
$table->integer( 'parent_id' )->nullable();
$table->integer( 'lft' )->nullable();
$table->integer( 'rgt' )->nullable();
$table->integer( 'depth' )->nullable();
$table->string( 'name' , 255);
$table->timestamps();
});
}
}</code>
|
4. 配置数据模型
继承 BaumNode
code1 2 3 | <code class = "php" > class Category extends Baum\Node
{
}</code>
|
继承后有这些属性可以重写:
code1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | <code class = "php" > class Category extends Baum\Node
{
protected $table = 'categories' ;
protected $parentColumn = 'parent_id' ;
protected $leftColumn = 'lidx' ;
protected $rightColumn = 'ridx' ;
protected $depthColumn = 'nesting' ;
protected $guarded = array( 'id' , 'parent_id' , 'lidx' , 'ridx' , 'nesting' );
}</code>
|
至此集成成功。
使用
引用:https://phphub.org/topics/2123
集成 etrepat/baum 让标签具备从属关系。
code1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | <code class = "php" >
$root = Tag::create([ 'name' => 'Root' ]);
$child1 = $root->children()->create([ 'name' => 'Child1' ]);
$child = Tag::create([ 'name' => 'Child2' ]);
$child->makeChildOf($root);
$tagTree = [
'name' => 'RootTag' ,
'children' => [
[ 'name' => 'L1Child1' ,
'children' => [
[ 'name' => 'L2Child1' ],
[ 'name' => 'L2Child1' ],
[ 'name' => 'L2Child1' ],
]
],
[ 'name' => 'L1Child2' ],
[ 'name' => 'L1Child3' ],
]
];
Tag::buildTree($tagTree);</code>
|
更多关联操作请查看:etrepat/baum 。
以上就是对使用 Baum 嵌套集合模型来实现 Laravel 模型的无限极分类的相关介绍,希望对您学习PHP有所帮助,感谢您关注织梦者!