繁体   English   中英

Laravel API仅获取帖子类别

[英]Laravel API get categories with posts only

我有API资源,可以在我的API控制器中调用它,以便它返回我的数据,我需要在此API中添加一个额外的过滤器,但不确定如何?

我需要的

  1. 获取仅具有帖子的类别。
  2. 排除类别而不发布结果。

我有的

  1. 有和没有帖子的所有类别的列表。

Resource

<?php

namespace App\Http\Resources;

use Illuminate\Http\Resources\Json\JsonResource;
use App\Http\Resources\PostResource;

class CategoryResource extends JsonResource
{
    /**
     * Transform the resource into an array.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return array
     */
    public function toArray($request)
    {
        return [
            'id' => $this->id,
            'title' => $this->title,
            'image' => url('images', $this->photo),
            'url' => $this->slug,
            'posts' => PostResource::collection($this->whenLoaded('posts')),
            'created_at' => (string) $this->created_at,
            'updated_at' => (string) $this->updated_at,
        ];
    }
}

Controller

<?php

namespace App\Http\Controllers\API;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Http\Resources\CategoryResource;
use App\Category;

class CategoryController extends Controller
{
    public function index(){
        $categories = CategoryResource::collection(Category::where('status', '1')->with('posts')->orderby('id', 'desc')->get());
        return response()->json($categories);
    }
}

知道如何在我的控制器中添加该过滤器吗?

您可以使用has函数过滤至少有一个帖子的类别:

Category::where('status', '1')->with('posts')->has('posts')->orderby('id', 'desc')->get();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM