【发布时间】:2022-01-16 15:16:29
【问题描述】:
我正在开发一个使用 innertia、vue 堆栈的 laravel 项目。在我的项目中,一些模型具有隐藏属性。我想让它们在某些路线上可见。但我不能将 makeVisible() 与查询生成器一起使用。有解决办法吗?
控制器中的方法
$hosters = Hoster::query()
->when($request->input('search'), function ($query, $search) {
if ($search == "approved") {
return $query->where('is_approved', '=', true);
} elseif ($search == "notapproved") {
return $query->where('is_approved', '=', false);
}
return $query
->where('name', 'like', '%' . $search . '%')
->orWhere('contact_number', 'like', '%' . $search . '%')
->orWhere('email', 'like', '%' . $search . '%');
})
->orderBy('created_at', 'desc')
->paginate(8)
->withQueryString();
return Inertia::render('Hoster/Show', [
'hosters' => $hosters,
'filters' => $request->only(['search']),
]);
模型中的隐藏字段
protected $hidden = [
'past_works',
'anchor',
'contact_number',
'email'
];
【问题讨论】:
标签: php laravel laravel-query-builder