按標籤搜尋貼文
P粉323050780
P粉323050780 2024-04-03 22:38:54
0
1
693

我需要按標籤顯示貼文。我的解決方案適用於單一標籤,如下所示:

路線:

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”標籤?

P粉323050780
P粉323050780

全部回覆(1)
P粉596161915

使用查詢字串的 GET 請求可以接受多個參數。而不是?tag=test&unit (無論如何都不會真正起作用,因為&unit 將被解析為$request->input('unit'),並且將是null& 是保留字元),您可以發送為:

http://127.0.0.1:8000/posts?tags[]=test&tags[]=unit

在後端,當你存取 request()->input('tags') 時,你會得到以下陣列:

$tags = request()->input('tags'); // ['test', 'unit']

所以,把它們放在一起:

// ScopeFilter method on your `Post` Model
public function scopeFilter($query, array $tagNames) {
  if (!empty($tagNames)) {
    $tagIds = Tag::whereIn('name', $tagNames)->pluck('id');

    return $query->whereHas('tags', function($subQuery) use ($tagIds) {
      return $subQuery->whereIn('tags.id', $tagIds);
    });

    // Alternative without `$tagIds`, using `$tagNames` directly
    // return $query->whereHas('tags', function($subQuery) use ($tagNames) {
    //   return $subQuery->whereIn('tags.name', $tagNames);
    // });
  }

  return $query;
}

// Usage
public function index() {
  return view('posts', [
    'posts' => Post::latest()->filter(request()->input('tags', []))->get()
  ]);
}
  • 調整查詢以使用 whereIn() 處理多個值
  • 使用request()->input('tags', []) 存取?tags[]=...&tags[]=...,如果未提供則為空數組。
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板