使用 Laravel Eloquent 的 hasMany 來開發無限極分類
下面由Laravel開發入門教學專欄為大家介紹使用 Laravel Eloquent 的 hasMany 來開發無限極分類的方法,希望對需要的朋友有所幫助!
在網路商城上,我們經常可以看到多層分類、子分類、甚至無限極分類。本文將向你展示如何優雅的透過 Laravel Eloquent 將其實現。
我們會建立一個微型項目來展示兒童商店的分類,總共有5 級,如下:
資料庫遷移
簡單的資料表結構:
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(); });
只有一個name 字段, 關聯到其自身。所以,大部分父級分類category_id = NULL,每個子分類都有一個parent_id
資料表資料如下:
Eloquent 模型和關聯關係
首先,在app/Category.php 創建一個簡單的hasMany() 方法, 分類可能擁有其自分類:
class Category extends Model { public function categories() { return $this->hasMany(Category::class); } }
好戲開場本文最妙“計策」。你知道可以向這樣描述 遞歸 關係嗎?如下:
public function childrenCategories() { return $this->hasMany(Category::class)->with('categories'); }
因此,如果呼叫 Category::with(‘categories’),將得到下級 “子分類”,但是透過 Category::with(‘childrenCategories’) 將能幫你實現無限極。
路由和控制器方法
現在,讓我們嘗試顯示所有類別和子類別,如上例所示。
在routes/web.php,我們加入以下內容:
Route::get('categories', 'CategoryController@index');
app/Http/CategoryController.php 如下所示:
public function index() { $categories = Category::whereNull('category_id') ->with('childrenCategories') ->get(); return view('categories', compact('categories')); }
我們只載入父類別,將子類別作為關係。簡單吧?
檢視與遞歸子視圖
最後,渲染到頁面。在 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>
我們先遍歷了最頂級的父類別,然後遍歷出父類別的子類別,然後使用 @include 載入子類別的子類別.. ....
最好的部分是resources/views/admin/child_category.blade.php 將使用遞歸載入自身。看程式碼:
<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
在 child_category.blade.php 內部,我們包含了 @include(‘child_category’),因此只要目前子類別中有類別,模板就會遞歸地載入子類別。
就是這樣!我們擁有無限級別的子類別 - 無論是在資料庫還是關聯關係或是視圖中
更多laravel框架技術文章,請訪問laravel教程!
以上是使用 Laravel Eloquent 的 hasMany 來開發無限極分類的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Laravel郵件發送失敗時的退信代碼獲取方法在使用Laravel開發應用時,經常會遇到需要發送驗證碼的情況。而在實�...

在dcatadmin(laravel-admin)中如何實現自定義點擊添加數據的表格功能在使用dcat...

Laravel框架中Redis連接的共享與select方法的影響在使用Laravel框架和Redis時,開發者可能會遇到一個問題:通過配置...

在Laravel多租戶擴展包stancl/tenancy中自定義租戶數據庫連接使用Laravel多租戶擴展包stancl/tenancy構建多租戶應用時,...

LaravelEloquent模型檢索:輕鬆獲取數據庫數據EloquentORM提供了簡潔易懂的方式來操作數據庫。本文將詳細介紹各種Eloquent模型檢索技巧,助您高效地從數據庫中獲取數據。 1.獲取所有記錄使用all()方法可以獲取數據庫表中的所有記錄:useApp\Models\Post;$posts=Post::all();這將返回一個集合(Collection)。您可以使用foreach循環或其他集合方法訪問數據:foreach($postsas$post){echo$post->

在Laravel6項目中如何檢查Redis連接的有效性是一個常見的問題,特別是在項目依賴於Redis進行業務處理時。以下是...

Laravel數據庫遷移過程中出現類重複定義問題在使用Laravel框架進行數據庫遷移時,開發者可能會遇到“類已使用�...

Laravel 是一款 PHP 框架,用於輕鬆構建 Web 應用程序。它提供一系列強大的功能,包括:安裝: 使用 Composer 全局安裝 Laravel CLI,並在項目目錄中創建應用程序。路由: 在 routes/web.php 中定義 URL 和處理函數之間的關係。視圖: 在 resources/views 中創建視圖以呈現應用程序的界面。數據庫集成: 提供與 MySQL 等數據庫的開箱即用集成,並使用遷移來創建和修改表。模型和控制器: 模型表示數據庫實體,控制器處理 HTTP 請求。
