首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在雄辩的资源中使用分页在Laravel中抛出未定义的属性$id错误

在雄辩的资源中使用分页在Laravel中抛出未定义的属性$id错误
EN

Stack Overflow用户
提问于 2019-01-03 03:12:32
回答 1查看 2.1K关注 0票数 1

我正在尝试在Laravel 5.7中构建一个应用程序,其中有一个名为CompanyBehaviour的模型

代码语言:javascript
复制
protected $table = 'company_behaviour';

protected $guarded= [];

public function companies()
{
    return $this->belongsTo('Noetic\Plugins\Conxn\Models\Company','company_id','id');
}

public function companyRole()
{
    return $this->belongsTo('Noetic\Plugins\Conxn\Models\Variables\Company\Role', 'company_role_id', 'id');
}

public function companySpecialisation()
{
    return $this->belongsTo('Noetic\Plugins\Conxn\Models\Variables\Company\Role', 'company_specialisation_id', 'id');
}

我有一个这样的资源文件:

代码语言:javascript
复制
class CompanyBehaviourResource extends JsonResource
{
    /**
     * Transform the resource into an array.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return array
     */
    public function toArray($request)
    {
        return [
            'id' => $this->id,
            'company' => $this->company->name,
            'company_role' => $this->companyRole->name,
            'company_specialisation' => $this->companySpecialisation->name,
        ];
    }
}

我需要在获取控制器中的数据时使用它:

代码语言:javascript
复制
public function index(Request $request)
{

    return new CompanyBehaviourResource(CompanyBehaviour::whereHas('companies', function ($q) use($request) {
        $q->where('name', 'like', '%'.$request->search.'%');
    })->orderBy('created_at', 'desc')
        ->paginate(20)
    );
}

但是当我调用这个的时候,我得到了分页错误:

Illuminate\Pagination\LengthAwarePaginator::$id未定义的

属性

而跟踪则表示:

代码语言:javascript
复制
class: "Illuminate\Http\Resources\Json\JsonResource"
file: "D:\~Resource\CompanyBehaviourResource.php"
function: "__get"
line: 17
type: "->"

'id' => $this->id,声明为此行。我已经看过了Laravel Resource API的文档,我找不到哪里做错了。帮我解决这个问题。谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-01-03 03:29:14

您的调用返回雄辩的集合,而不是单个结果,因此不持有$id属性。您应该改为调用集合方法:

代码语言:javascript
复制
public function index(Request $request)
{

    return new CompanyBehaviourResource::collection(CompanyBehaviour::whereHas('companies', function ($q) use($request) {
        $q->where('name', 'like', '%'.$request->search.'%');
    })->orderBy('created_at', 'desc')
        ->paginate(20)
    );
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54011913

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档