


Verwenden von hasMany von Laravel Eloquent zur Entwicklung der Infinitus-Klassifizierung
Die folgende Einführungs-Tutorial-Kolumne, die von Laravel entwickelt wurde, stellt Ihnen die Methode zur Verwendung von Laravel Eloquents hasMany zur Entwicklung der Infinitus-Klassifizierung vor. Ich hoffe, dass sie Freunden in Not hilfreich sein wird! In Online-Einkaufszentren können wir oft mehrstufige Kategorien, Unterkategorien und sogar Infinitus-Kategorien sehen. Dieser Artikel zeigt Ihnen, wie Sie es mit Laravel Eloquent elegant umsetzen.
Wir werden ein Mikroprojekt erstellen, um die Klassifizierung von Kindergeschäften mit insgesamt 5 Ebenen wie folgt anzuzeigen:
Einfache Datentabellenstruktur:
Schema::create('categories', function (Blueprint $table) { $table->bigIncrements('id'); $table->string('name'); $table->unsignedBigInteger('category_id')->nullable(); $table->foreign('category_id')->references('id')->on('categories'); $table->timestamps(); });
hat nur ein Namensfeld, das sich auf sich selbst bezieht. Daher ist die Kategorie_ID der meisten übergeordneten Kategorien NULL und jede Unterkategorie hat eine übergeordnete_ID
Die Datentabellendaten lauten wie folgt:
Erstellen Sie zunächst eine einfache hasMany()-Methode in app/Category.php. Kategorien können ihre eigenen Selbstkategorien haben:
class Category extends Model { public function categories() { return $this->hasMany(Category::class); } }
Das Beste an diesem Artikel ist der Beginn der Show „Plan“. Wussten Sie, dass Sie eine rekursive Beziehung wie diese beschreiben können? Wie folgt:
public function childrenCategories() { return $this->hasMany(Category::class)->with('categories'); }
Wenn Sie also Category::with('categories') aufrufen, erhalten Sie die „Unterkategorien“ der unteren Ebene, aber die Verwendung von Category::with('childrenCategories') wird Ihnen helfen Unendlichkeit erreichen.
Routen und Controller-MethodenVersuchen wir nun, alle Kategorien und Unterkategorien anzuzeigen, wie im obigen Beispiel gezeigt.
In Routen/web.php fügen wir Folgendes hinzu:
Route::get('categories', 'CategoryController@index');
app/Http/CategoryController.php wie folgt:
public function index() { $categories = Category::whereNull('category_id') ->with('childrenCategories') ->get(); return view('categories', compact('categories')); }
Wir laden nur die übergeordnete Kategorie, die Unterkategorien werden als Beziehungen bezeichnet. Einfach, oder?
Ansichten und rekursive UnteransichtenZum Schluss rendern Sie auf der Seite. In der Datei resources/views/categories.blade.php:
<ul> @foreach ($categories as $category) <li>{{ $category->name }}</li> <ul> @foreach ($category->childrenCategories as $childCategory) @include('child_category', ['child_category' => $childCategory]) @endforeach </ul> @endforeach </ul>
durchlaufen wir zuerst die übergeordnete Kategorie der obersten Ebene, dann die Unterkategorien der übergeordneten Kategorie und verwenden dann @include, um die Unterkategorien von zu laden die Unterkategorie.. ....
Das Beste daran ist, dass resources/views/admin/child_category.blade.php sich selbst rekursiv lädt. Schauen Sie sich den Code an:
<li>{{ $child_category->name }}</li> @if ($child_category->categories) <ul> @foreach ($child_category->categories as $childCategory) @include('child_category', ['child_category' => $childCategory]) @endforeach </ul> @endif
In child_category.blade.php fügen wir @include(‘child_category’) ein, sodass die Vorlage Unterkategorien rekursiv lädt, solange es Kategorien in der aktuellen Unterkategorie gibt.
Das ist es! Wir verfügen über unbegrenzte Ebenen an Unterkategorien – ob in Datenbanken, Beziehungen oder Ansichten
Weitere technische Artikel zum Laravel-Framework finden Sie in den
Laravel-Tutorials!
Das obige ist der detaillierte Inhalt vonVerwenden von hasMany von Laravel Eloquent zur Entwicklung der Infinitus-Klassifizierung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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 ...

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->

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

Verarbeiten Sie 7 Millionen Aufzeichnungen effizient und erstellen Sie interaktive Karten mit Geospatial -Technologie. In diesem Artikel wird untersucht, wie über 7 Millionen Datensätze mithilfe von Laravel und MySQL effizient verarbeitet und in interaktive Kartenvisualisierungen umgewandelt werden können. Erstes Herausforderungsprojektanforderungen: Mit 7 Millionen Datensätzen in der MySQL -Datenbank wertvolle Erkenntnisse extrahieren. Viele Menschen erwägen zunächst Programmiersprachen, aber ignorieren die Datenbank selbst: Kann sie den Anforderungen erfüllen? Ist Datenmigration oder strukturelle Anpassung erforderlich? Kann MySQL einer so großen Datenbelastung standhalten? Voranalyse: Schlüsselfilter und Eigenschaften müssen identifiziert werden. Nach der Analyse wurde festgestellt, dass nur wenige Attribute mit der Lösung zusammenhängen. Wir haben die Machbarkeit des Filters überprüft und einige Einschränkungen festgelegt, um die Suche zu optimieren. Kartensuche basierend auf der Stadt
