Heim >Backend-Entwicklung >PHP-Tutorial >Laravel implementiert eine unendliche Klassifizierung

Laravel implementiert eine unendliche Klassifizierung

大家讲道理
大家讲道理Original
2017-02-22 14:00:544246Durchsuche

Erklärung

Jeder verwendet normalerweise Rekursion, um eine unendliche Klassifizierung zu implementieren. Hier wird ein Laravel-Erweiterungspaket empfohlen etrepat/baum, sorgen Sie dafür, dass Ihr Datenmodell schnell eine unendliche hierarchische Baumstruktur unterstützt und dabei die Effizienz berücksichtigt.

Verwenden Sie das verschachtelte Mengenmodell von Baum, um die unendliche Klassifizierung des Laravel-Modells zu implementieren

Die offizielle Dokumentation des Erweiterungspakets bietet Platz für Erklärungen, und das Bild unten ist auch ein einfaches Beispiel:

Laravel implementiert eine unendliche Klassifizierung

Anwendungsfallbeschreibung #

Als nächstes sprechen wir über ein paar Beispiele für unendliche hierarchische Baummodelle.

Tag-System#

Referenz: Laravel Taggable Fügen Sie Ihrem Modell eine Tagging-Funktion hinzu. Ein Tag kann unzählige untergeordnete Tags haben, zu einem übergeordneten Tag gehören und mehrere Peer-Tags haben.

Zum Beispiel der Tag-Baum unten:

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

Kommentarsystem #

Unendlich verschachtelte Kommentare, wie das Kommentarsystem von NetEase.

Laravel implementiert eine unendliche Klassifizierung

Laravel verfügt über eine Kommentarerweiterung, die unendliche Verschachtelung unterstützt, siehe Slynova-Org/laravel-commentable.

Datenmodell „Navigationsleiste“#

Der Administratorhintergrund muss eine Anpassungsfunktion für die „Navigationsleiste“ und eine Navigationsleiste mit Baumstruktur bereitstellen.

Laravel implementiert eine unendliche Klassifizierung

Integrated Baum#

etrepat/baum ermöglicht es Ihrem Datenmodell schnell, die hierarchische Struktur des Infinitus-Baums zu unterstützen und gleichzeitig die Effizienz zu berücksichtigen.

Als nächstes werden wir darüber sprechen, wie man sich integriert.

1. Composer-Installation#

composer require "baum/baum:~1.1"

2. Anbieter# hinzufügen

Ändern Sie die config/app.php-Datei und fügen Sie Folgendes hinzu: providers Array >

'Baum\Providers\BaumServiceProvider',
Dieser Dienstanbieter registriert zwei Befehle:

, artisan baum. artisan  baum.install

3. Migration# erstellen

und auf dem vorhandenen Datenmodell installieren:

php artisan baum:install MODEL
Dann

php artisan migrate
über die Felder von ausführen Migrationseinführung#

  • parent_id: die ID des übergeordneten Knotens

  • lft: der linke Indexwert

  • rgt: Indexwert rechts

  • Tiefe: Ebenentiefe

Das Folgende ist ein Beispiel:

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. Konfigurieren Sie das Datenmodell #

BaumNode erben

class Category extends Baum\Node {}
Nach der Vererbung können diese Attribute überschrieben werden:

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');}
Die Integration ist erfolgreich.

Verwenden Sie

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


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn