Laravel-admin 查询过滤,如何筛选没评论数据的文章?

最近在学习 laravel-admin,有一个需求,看了很多手册和文档还是没有实现,请大佬给个建议或者想法,感谢!

需求:
在后台文章列表里,可以通过下拉选择筛选【是否有文章评论】来展示对应的文章数据。

已经定义好模型关联,文章列表使用以下可以显示 ID。

$grid->column('comment.id','是否有文章评论'->display($this->displayBool())->filter([true => '是', false => '否']);

这样设置是不能用的,请问该怎么实现呢?可以提供一个思路吗

《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
最佳答案

琢磨后,通过以下代码解决

$filter->where(function ($query) {
                    if ($this->input == 0) {
                        $query->doesntHave('commont');
                    } else {
                        $query->Has('commont');
                    }
                }, '是否有评论')->select([0 => 'No', 1 => 'Yes']);
});
4年前 评论
讨论数量: 2

$grid->filter (function ($filter) { $filter->in ('type', ' 是否有评论 ')->select (model::TYPE); }); 对应的 model 写: const NO = 0, YES = 1; const TYPE = [ self::NO=> ' 否 ', self::YES => ' 是 ' ];

4年前 评论

琢磨后,通过以下代码解决

$filter->where(function ($query) {
                    if ($this->input == 0) {
                        $query->doesntHave('commont');
                    } else {
                        $query->Has('commont');
                    }
                }, '是否有评论')->select([0 => 'No', 1 => 'Yes']);
});
4年前 评论