-
php教程之使用 Laravel Eloquent 的 hasMany 来开发无限极分类
本站最新发布 C#从入门到精通
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
在网上商城上,我们经常可以看到多级分类、子分类、甚至无限极分类。本文将向你展示如何优雅的通过 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() 方法, 分类可能拥有其自分类:
1
2
3
4
5
6
7
|
class Category extends Model { public function categories() { return $ this ->hasMany(Category:: class ); } } |
好戏开场 本文最妙 “计策”。你知道可以向这样描述 递归 关系吗?如下:
1
2
3
4
|
public function childrenCategories() { return $ this ->hasMany(Category:: class )->with( 'categories' ); } |
因此,如果调用 Category::with(‘categories’),将得到下级 “子分类”,但是通过 Category::with(‘childrenCategories’) 将能帮你实现无限极。
路由和控制器方法
现在,让我们尝试显示所有类别和子类别,如上例所示。
在 routes/web.php,我们添加以下内容:
1
|
Route:: get ( 'categories' , 'CategoryController@index' ); |
app/Http/CategoryController.php 如下所示:
1
2
3
4
5
6
7
|
public function index() { $categories = Category::whereNull( 'category_id' ) ->with( 'childrenCategories' ) -> get (); return view( 'categories' , compact( 'categories' )); } |
我们仅加载父类别,将子类别作为关系。简单吧?
视图和递归子视图
最后,渲染到页面。 在 resources/views/categories.blade.php 文件:
1
2
3
4
5
6
7
8
9
10
|
<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> |
最新更新
linux常用指令和一些选项的汇总
centos7下安装mysql6初始化安装密码
ubuntu之命令相关问题
文件系统格式化和挂载
关于Linux下内存和Swap
phpize安装php扩展(本文章以php7扩展mbstr
对FileStream的几种属性和方法认识
[原创][开源] SunnyUI.Net 字体图标
C# BinaryWriter BinaryReader demo
后台读取Html文件节点信息写入到新的ht
php安装扩展时报错:make: *** [mbstring.lo]
php多版本:已存在php5场景下,编译安装
编译安装apache2.2对应的mod_proxy_fcgi.so模块
linux修改环境变量分析
[apue] epoll 的一些不为人所注意的特性
树莓派使用 OLED 屏显示图片及文字
容器技术之Dockerfile(三)
【原创】Linux中断子系统(二)-通用框架
C# 在Word中添加Latex 数学公式和符号
inncheck命令 – 检查语法
access数据库远程连接
java web操作Access数据库
数据库学习总结(1)
二级Access数据库大纲知识要点
链接表的意义
《社工服务管理系统》Access开发心得
让ADO.NET Entity Framework 支持ACCESS数据库
C#连接Access
数据库实验系列之3存储过程和触发器实验
Excel 数据导入至Sqlserver 数据库中 ltrim()