0
Laravel: 5.6.39

PHP: 7.2.10

Yajra Table: 8.0

示例代码

$(document).ready( function() {
        var url = "{{ url('/admin/posts') }}";
        $(function() {
            var oTable = $('#admin-posts').DataTable({
                dom: "<'row'<'col-xs-12'<'col-xs-6'l><'col-xs-6'p>>r>"+
            "<'row'<'col-xs-12't>>"+
            "<'row'<'col-xs-12'<'col-xs-6'i><'col-xs-6'p>>>",
                processing: true,
                serverSide: true,
                ajax: {
                    url: url,
                    data: function (d) {
                        d.category = $("#category option:selected").val();
                        d.language = $("#language option:selected").val();
                    }
                },            
                columns: [
                    { data: 'post_checkbox', name: 'post_checkbox' },
                    { data: 'created_at', name: 'created_at' },
                    { data: 'post_label', name: 'post_label' },
                    { data: 'post_link', name: 'post_link' },
                    { data: 'view', name: 'view' },
                    { data: 'post_category', name: 'post_category' },
                ],
                stateSave: true,
                bDestroy: true,
          });

          $('#search-form').on('submit', function(e) {
               oTable.draw();
               e.preventDefault();
            });
        });
   });

现在,如果我要删除dom搜索和过滤器,两者都可以看到,但搜索仍然不起作用,如果我要删除过滤器,那么只有搜索工作,我相信应该对 dom 或其他东西进行一些自定义,这将允许搜索和过滤器.

文档中也没有搜索。

有一个选项可以像下面的代码一样启用搜索,但它似乎不起作用,因为我在上面的代码中删除了 dom 属性。

search: {
        "regex": true
    }
4

1 回答 1

2

我不知道搜索是如何自动工作的,但我已经根据我的要求进行了编码,并且工作正常并给出了一些想法,你可以如何做到这一点。

您可以使用获取搜索词$request->get('search')['value'],现在编写代码来检查您的条件是否得到满足,并在您的控制器或模型中过滤结果。以下是在 Controller 中执行此操作的代码。

return DataTables::eloquent($posts)
        ->filter(function ($query) use ($request) {
            if ($request->has('category') && ! is_null($request->get('category'))) {
                $query->where('post_category', $request->get('category'));
            }

            if ($request->has('language') && ! is_null($request->get('language')) ) {
                $query->where('post_language', $request->get('language'));
            }
            
            if ($request->has('search') && ! is_null($request->get('search')['value']) ) {
                $regex = $request->get('search')['value'];
                return $query->where('your_field', 'like', '%' . $regex . '%');
                });
            }
        })->toJson();
于 2019-03-08T12:18:20.867 回答