Laravel implementiert eine unendliche Klassifizierung
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:
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 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.
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
<🎜 in der
'Baum\Providers\BaumServiceProvider',
, artisan baum
. artisan baum.install
php artisan baum:install MODEL
php artisan migrate
- parent_id: die ID des übergeordneten Knotens
- lft: der linke Indexwert
- rgt: Indexwert rechts
- Tiefe: Ebenentiefe
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(); }); }}
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);

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Methode zum Abholen des Rücksendecode, wenn das Senden von Laravel -E -Mails fehlschlägt. Wenn Sie Laravel zur Entwicklung von Anwendungen verwenden, stellen Sie häufig Situationen auf, in denen Sie Überprüfungscodes senden müssen. Und in Wirklichkeit ...

Laravel -Zeitplan -Aufgabe Ausführen nicht reagierende Fehlerbehebung Bei Verwendung der Zeitplanung von Laravel -Zeitplänen werden viele Entwickler auf dieses Problem stoßen: Zeitplan: Run ...

Die Methode zum Umgang mit Laravels E -Mail -Versagen zum Senden von Verifizierungscode besteht darin, Laravel zu verwenden ...

So implementieren Sie die Tabellenfunktion von benutzerdefiniertem Klicken, um Daten in dcatadmin (laravel-admin) hinzuzufügen, wenn Sie DCAT verwenden ...

Die Auswirkungen des Austauschs von Redis -Verbindungen im Laravel -Framework und der Auswahl von Methoden bei Verwendung von Laravel -Framework und Redis können Entwickler auf ein Problem stoßen: Durch Konfiguration ...

Benutzerdefinierte Mieterdatenbankverbindung in Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis beim Erstellen von Multi-Mandanten-Anwendungen mit Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis, ...

Laraveleloquent-Modellab Abruf: Das Erhalten von Datenbankdaten Eloquentorm bietet eine prägnante und leicht verständliche Möglichkeit, die Datenbank zu bedienen. In diesem Artikel werden verschiedene eloquente Modellsuchtechniken im Detail eingeführt, um Daten aus der Datenbank effizient zu erhalten. 1. Holen Sie sich alle Aufzeichnungen. Verwenden Sie die Methode All (), um alle Datensätze in der Datenbanktabelle zu erhalten: UseApp \ Models \ post; $ posts = post :: all (); Dies wird eine Sammlung zurückgeben. Sie können mit der Foreach-Schleife oder anderen Sammelmethoden auf Daten zugreifen: foreach ($ postas $ post) {echo $ post->

Ein Problem der doppelten Klassendefinition während der Laravel -Datenbankmigration tritt auf. Bei Verwendung des Laravel -Frameworks für die Datenbankmigration können Entwickler "Klassen" verwendet ...
