繁体   English   中英

如何在 laravel queryBuilder 中使隐藏属性可见?

[英]How to make visible hidden attributes in laravel queryBuilder?

我正在开发一个 laravel 项目,该项目使用的是 innertia,vue 堆栈。 在我的项目中,一些模型具有隐藏属性。 我想让它们在某些路线上可见。 但我不能将 makeVisible() 与查询生成器一起使用。 有解决办法吗?

controller 中的方法

    $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']),
        ]);

model 中的隐藏字段

    protected $hidden = [
        'past_works',
        'anchor',
        'contact_number',
        'email'
    ];

使用makeVisible方法

makeVisible 方法使通常在集合中每个 model 上“隐藏”的属性可见

$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();

    $hosters->makeVisible([
        'past_works'
    ]);

        return Inertia::render('Hoster/Show', [
            'hosters' => $hosters,
            'filters' => $request->only(['search']),
        ]);

参考: https://laravel.com/docs/8.x/eloquent-collections#method-makeVisible参考: https://github.com/laravel/framework/issues/16501

暂无
暂无

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

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