如何使用Laravel Eloquent来开发无限极分类

2025-05-29 0 28

概述

我们会创建一个微型项目来展示儿童商店的分类,总共有 5 级,如下:

如何使用Laravel Eloquent来开发无限极分类

数据库迁移

简单的数据表结构:

只有一个 name 字段, 关联到其自身。所以,大部分父级分类 category_id = null,每一个子分类都有一个 parent_id

数据表数据如下:

如何使用Laravel Eloquent来开发无限极分类

eloquent 模型和关联关系

首先,在 app/category.php 创建一个简单的 hasmany() 方法, 分类可能拥有其自分类:

好戏开场 本文最妙 “计策”。你知道可以向这样描述 递归 关系吗?如下:

因此,如果调用 category::with(‘categories'),将得到下级 “子分类”,但是通过 category::with(‘childrencategories') 将能帮你实现无限极。

路由和控制器方法

现在,让我们尝试显示所有类别和子类别,如上例所示。

在 routes/web.php,我们添加以下内容:

app/http/categorycontroller.php 如下所示:

我们仅加载父类别,将子类别作为关系。简单吧?

视图和递归子视图

最后,渲染到页面。 在 resources/views/categories.blade.php 文件:

我们先遍历了最顶级的父类别,然后遍历出父类的子类别,然后使用 @include 加载子类别的子类别……

最好的部分是 resources/views/admin/child_category.blade.php 将使用递归加载自身。看代码:

在 child_category.blade.php 内部,我们包含了 @include(‘child_category'),因此只要当前子类别中有类别,模板就会递归地加载子类别。

就是这样!我们拥有无限级别的子类别 – 无论是在数据库还是关联关系或是视图中

以上就是如何使用laravel eloquent来开发无限极分类的详细内容,更多关于使用laravel eloquent来开发无限极分类的资料请关注快网idc其它相关文章!

原文链接:https://www.cnblogs.com/a609251438/p/12868914.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 如何使用Laravel Eloquent来开发无限极分类 https://www.kuaiidc.com/90046.html

相关文章

发表评论
暂无评论