首頁  >  文章  >  後端開發  >  laravel實現無限極分類

laravel實現無限極分類

大家讲道理
大家讲道理原創
2017-02-22 14:00:544032瀏覽

說明

大家通常都是使用遞歸實現無限極分類,都知道遞歸效率很低,下面推薦一個Laravel 的擴充包etrepat/baum,快速讓你的資料模型支援無限極樹狀層級結構,並且兼顧效率。

使用Baum 巢狀集合模型來實現Laravel 模型的無限極分類

擴充包的官方文件裡有解釋的篇幅,下面這張圖的也是一個簡單的例子:

laravel實現無限極分類

用例說明

#接下來講幾個無限樹狀層級模型的例子。

標籤系統

#參考:Laravel Taggable 為你的模型添加打標籤功能一個標籤可以有無數多子標籤,屬於一個父標籤,有多個同儕標籤。

如下面的這顆標籤樹:

$tagTree = [
    'name' => 'RootTag',
    'children' => [
        ['name' => 'L1Child1',
            'children' => [
                ['name' => 'L2Child1'],
                ['name' => 'L2Child1'],
                ['name' => 'L2Child1'],
            ]
        ],
        ['name' => 'L1Child2'],
        ['name' => 'L1Child3'],
    ]];

評論系統

##評論的無限極別嵌套,如網易的 跟帖系統。

laravel實現無限極分類

Laravel 有一個評論擴充功能支援無限極別嵌套,請見 Slynova-Org/laravel-commentable。

「導覽列」資料模型

#管理員後台需要提供「導覽列」自訂功能,樹狀結構導覽列。

laravel實現無限極分類

整合 Baum

#etrepat/baum 快速讓你的資料模型支援無限極樹狀層級結構,且兼顧效率。

接下來我們講如何整合。

1. composer 安裝

#
composer require "baum/baum:~1.1"

2. 增加provider

#修改config/app.php 文件,在providers 陣列中新增:

'Baum\Providers\BaumServiceProvider',

此服務提供者註冊了兩個指令:artisan baum, artisan  baum.install

3. 建立migration

#安裝到已存在的資料模型上:

php artisan baum:install MODEL

然後執行

php artisan migrate

關於migration 的欄位介紹

  • #parent_id: 父節點的id

  • #lft:左邊索引值

  • ##rgt: 右邊索引值

  • depth: 層級深度

#以下是個範例:

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();
    });
  }}

4. 配置資料模型

# #繼承Baum\Node

class Category extends Baum\Node {}

繼承後有這些屬性可以重寫:

class Category extends Baum\Node {
  protected $table = 'categories';

  // 'parent_id' column name
  protected $parentColumn = 'parent_id';

  // 'lft' column name
  protected $leftColumn = 'lidx';

  // 'rgt' column name
  protected $rightColumn = 'ridx';

  // 'depth' column name
  protected $depthColumn = 'nesting';

  // guard attributes from mass-assignment
  protected $guarded = array('id', 'parent_id', 'lidx', 'ridx', 'nesting');}

至此整合成功。

使用

$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);


#

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn