Laravel implementiert eine unendliche Klassifizierung

大家讲道理
Freigeben: 2023-03-05 22:24:02
Original
4200 Leute haben es durchsucht

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'],
    ]];
Nach dem Login kopieren

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"
Nach dem Login kopieren

2. Anbieter# hinzufügen

Ändern Sie die config/app.php-Datei und fügen Sie Folgendes hinzu: providers<🎜 in der

Array >
&#39;Baum\Providers\BaumServiceProvider&#39;,
Nach dem Login kopieren
Dieser Dienstanbieter registriert zwei Befehle:

, artisan baum. artisan baum.install

3. Migration# erstellen

und auf dem vorhandenen Datenmodell installieren:

php artisan baum:install MODEL
Nach dem Login kopieren
Dann

php artisan migrate
Nach dem Login kopieren
ü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(&#39;categories&#39;, function(Blueprint $table) {
      $table->increments(&#39;id&#39;);

         // 这四行代码
      $table->integer(&#39;parent_id&#39;)->nullable();
      $table->integer(&#39;lft&#39;)->nullable();
      $table->integer(&#39;rgt&#39;)->nullable();
      $table->integer(&#39;depth&#39;)->nullable();

      $table->string(&#39;name&#39;, 255);

      $table->timestamps();
    });
  }}
Nach dem Login kopieren
4. Konfigurieren Sie das Datenmodell #

BaumNode erben

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

class Category extends Baum\Node {
  protected $table = &#39;categories&#39;;

  // &#39;parent_id&#39; column name
  protected $parentColumn = &#39;parent_id&#39;;

  // &#39;lft&#39; column name
  protected $leftColumn = &#39;lidx&#39;;

  // &#39;rgt&#39; column name
  protected $rightColumn = &#39;ridx&#39;;

  // &#39;depth&#39; column name
  protected $depthColumn = &#39;nesting&#39;;

  // guard attributes from mass-assignment
  protected $guarded = array(&#39;id&#39;, &#39;parent_id&#39;, &#39;lidx&#39;, &#39;ridx&#39;, &#39;nesting&#39;);}
Nach dem Login kopieren
Die Integration ist erfolgreich.

Verwenden Sie

$root = Tag::create([&#39;name&#39; => &#39;Root&#39;]);

// 创建子标签
$child1 = $root->children()->create([&#39;name&#39; => &#39;Child1&#39;]);

$child = Tag::create([&#39;name&#39; => &#39;Child2&#39;]);
$child->makeChildOf($root);

// 批量构建树
$tagTree = [
    &#39;name&#39; => &#39;RootTag&#39;,
    &#39;children&#39; => [
        [&#39;name&#39; => &#39;L1Child1&#39;,
            &#39;children&#39; => [
                [&#39;name&#39; => &#39;L2Child1&#39;],
                [&#39;name&#39; => &#39;L2Child1&#39;],
                [&#39;name&#39; => &#39;L2Child1&#39;],
            ]
        ],
        [&#39;name&#39; => &#39;L1Child2&#39;],
        [&#39;name&#39; => &#39;L1Child3&#39;],
    ]
];

Tag::buildTree($tagTree);
Nach dem Login kopieren


Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage