我需要按标签显示帖子。我的解决方案适用于单个标签,如下所示:
路线:
Route::get('/posts', [PostController::class, 'index'])->middleware('auth');
后模型过滤器:
public function scopeFilter($query, array $filters) { if ($filters['tag'] ?? false) { $tagId = Tag::where('name', $filters['tag'])->first()->id; $query->whereHas('tags', function($q) use ($tagId) { $q->where('tag_id', $tagId); }); } }
PostController 的方法索引:
public function index() { return view('posts', [ 'posts' => Post::latest()->filter(request(['tag']))->get() ]); }
此代码适用于如下网址:“http://127.0.0.1:8000/posts/?tag=test”。但我需要找到一种方法来搜索具有更多标签的帖子,例如我想查找带有“test”和“unit”标签的帖子。为此,我想使用如下网址:“http://127.0.0.1:8000/posts/?tag=test&unit”。我卡住了,因为我认为“request(['tag'])”将返回“test&unit”,但它只返回“test”。是否有可能以某种方式从此请求中获取“unit”标签?
使用查询字符串的
GET
请求可以接受多个参数。而不是?tag=test&unit
(无论如何都不会真正起作用,因为&unit
将被解析为$request->input('unit')
,并且将是null
,&
是保留字符),您可以发送为:在后端,当你访问
request()->input('tags')
时,你会得到以下数组:所以,把它们放在一起:
whereIn()
处理多个值request()->input('tags', [])
访问?tags[]=...&tags[]=...
,如果未提供则为空数组。