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

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

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

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

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

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

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 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年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!