laravel后台项目优化,前台首页数据api 一、后台项目

这是我参与11月更文挑战的第7天,活动详情查看:2021最后一次更文挑战

一、后台项目问题

1.1 用户列表的禁用启用字段返回

可以看到现在用户列表没有禁用获取启用的字段:
在这里插入图片描述


添加:
在这里插入图片描述
效果:
在这里插入图片描述


1.2 给所有搜索增加索引

给所有搜索增加索引(需要搜索的字段)可以提高我们的搜索的效率(索引也不是越多越好,越多的话,它也会占空间)。
给商品迁移文件增加索引:
在这里插入图片描述


给评论迁移文件增加索引:
在这里插入图片描述


给订单迁移文件增加索引:
在这里插入图片描述


1.3 订单表迁移文件,快递和单号可以为空

在这里插入图片描述


1.4 放弃并重新执行所有的迁移

执行命令php artisan migrate:refresh --seed,刷新所有的迁移同时运行数据填充:
在这里插入图片描述
至此我们关于后台相关的api基本上已经完成了。接下去开始弄前台相关的功能。

二、前台首页数据

2.1 创建控制器

运行命令php artisan make:controller Web/IndexController
在这里插入图片描述
在这里插入图片描述
写入首页获取数据方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
php复制代码<?php

namespace App\Http\Controllers\Web;

use App\Http\Controllers\BaseController;
use App\Models\Good;
use App\Models\Slide;

class IndexController extends BaseController
{
// 首页数据
function index() {
// 轮播图数据
$slides = Slide::where('status', 1)
->orderBy('seq') // 排序 默认正序
->get();

// 分类数据 没被禁用的分类
$categories = cache_category();

// 推荐商品
$goods = Good::where('is_on', 1) // 上架的商品
->where('is_recommend', 1) // 推荐的商品
->get();

return $this->response->array([
'slides' => $slides,
'categories' => $categories,
'goods' => $goods,
]);
}
}

2.2 前台路由

routes/api.php这里写我们的前台路由:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
php复制代码<?php

use App\Http\Controllers\Web\IndexController;

$api = app('Dingo\Api\Routing\Router');

$api->version('v1', function ($api) {

// 首页数据,不需要登陆就能获取
$api->get('/index', [IndexController::class, 'index']);

// 需要登陆的路由
$api->group(['middleware' => ['api.auth', 'check.permission']], function ($api) {

});
});

2.3 创建分类填充

运行命令php artisan make:seed CategorySeeder 创建分类的填充文件:
在这里插入图片描述


对分类进行数据添加:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
php复制代码<?php

namespace Database\Seeders;

use App\Models\Category;
use Illuminate\Database\Seeder;

class CategorySeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
// 填充分类信息
$categories = [
[
'name' => '电子产品',
'group' => 'goods',
'pid' => 0,
'level' => 1,
'children' => [
[
'name' => '手机',
'group' => 'goods',
'level' => 2,
'children' => [
[
'name' => '华为',
'group' => 'goods',
'level' => 3,
],
[
'name' => 'oppo',
'group' => 'goods',
'level' => 3,
],
]
],
[
'name' => '相机',
'group' => 'goods',
'level' => 2,
'children' => [
[
'name' => '索尼',
'group' => 'goods',
'level' => 3,
],
[
'name' => '佳能',
'group' => 'goods',
'level' => 3,
],
]
]
]
],
[
'name' => '车',
'group' => 'goods',
'pid' => 0,
'level' => 1,
'children' => [
[
'name' => '轿车',
'group' => 'goods',
'level' => 2,
'children' => [
[
'name' => '红旗',
'group' => 'goods',
'level' => 3,
],
[
'name' => '吉利',
'group' => 'goods',
'level' => 3,
],
]
],
[
'name' => '自行车',
'group' => 'goods',
'level' => 2,
'children' => [
[
'name' => '小黄车',
'group' => 'goods',
'level' => 3,
],
[
'name' => '小蓝车',
'group' => 'goods',
'level' => 3,
],
]
]
]
]
];

// 填充到数据库
foreach($categories as $one) {
$l1 = $one;
unset($l1['children']);
$l1_model = Category::create($l1);
foreach($one['children'] as $two) {
$l2 = $two;
unset($l2['children']);
$l2['pid'] = $l1_model->id;
$l2_model = Category::create($l2);
$l2_model->children()->createMany($two['children']);
}
}

// 清除缓存
forget_cache_category_all();

}
}

执行填充命令:php artisan db:seed --class=CategorySeeder
在这里插入图片描述
效果:
在这里插入图片描述

在学习的php的路上,如果你觉得本文对你有所帮助的话,那就请关注点赞评论三连吧,谢谢,你的肯定是我写博的另一个支持。

本文转载自: 掘金

开发者博客 – 和开发相关的 这里全都有

0%