如何在 laravel 查询生成器中使隐藏属性可见?

Posted

技术标签:

【中文标题】如何在 laravel 查询生成器中使隐藏属性可见?【英文标题】:How to make visible hidden attributes in laravel queryBuilder? 【发布时间】: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'
    ];

【问题讨论】:

【参考方案1】:

使用makeVisible方法

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

    $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

【讨论】:

请注意,$hosters->makeVisible(['past_works']); 的返回是 Collection 的实例,而不是 LengthAwarePaginator

以上是关于如何在 laravel 查询生成器中使隐藏属性可见?的主要内容,如果未能解决你的问题,请参考以下文章

jquery中使元素显示和隐藏方法之间的区别

如何在发布版本中使标签不可见[关闭]

如何在 Laravel 中使非数据库模型具有两个属性

降低基类属性的可见性

如何切换 VueJs 组件的可见性?

重定向标头在 Laravel 中可见而不是隐藏