乌鸦嘴文档 乌鸦嘴文档
乌鸦嘴社区 (opens new window)
乌鸦嘴社区 (opens new window)
  • 入门

  • 数据列表

    • 表格基本使用
    • 列的基本使用
    • 列的显示和扩展
    • 行的使用和扩展
    • 工具栏
    • 树状表格
    • 组合表头
    • 表格数据源
    • 表格关联关系
    • 查询过滤
    • 列过滤器
    • 表格快捷搜索
      • Like搜索
        • 关联关系
      • 自定义搜索
      • 快捷语法搜索
        • 比较查询
        • In、NotIn查询
        • Between查询
        • 时间日期函数查询
        • Like查询
        • 正则查询
        • 多条件组合搜索
        • Label作为查询字段名称
      • 禁止自动提交
    • 表格规格筛选器
    • 数据导出
    • 快捷创建
    • 数据表格行内编辑
    • 数据表格事件
    • 表格字段翻译
    • 数据软删除
    • 头部和脚部
    • 表格异步渲染
  • 数据表单

  • 数据详情

  • 模型树

  • 数据仓库

  • 动作

  • 多语言

  • 开发扩展

  • 页面组件

  • 区块

  • 动作以及表单相应

  • 权限控制

  • 菜单

  • 帮助函数

  • 开发工具

  • 自定义登陆

  • 自定义头部导航

  • 更新日志

目录

表格快捷搜索

# 表格快捷搜索

快捷搜索是除了filter之外的另一个表格数据搜索方式,用来快速过滤你想要的数据,开启方式如下:

$grid->quickSearch();

// 设置表单提示值
$grid->quickSearch()->placeholder('搜索...');

这样表头会出现一个搜索框:

通过给quickSearch方法传入不同的参数,来设置不同的搜索方式,有下面几种使用方法

# Like搜索

第一种方式,通过设置字段名称来进行简单的like查询

$grid->quickSearch('title');

// 提交后模型会执行下面的查询
$model->where('title', 'like', "%{$input}%");

或者对多个字段做like查询:

$grid->quickSearch('title', 'desc', 'content');
// 或
$grid->quickSearch(['title', 'desc', 'content']);

// 提交后模型会执行下面的查询
$model->where('title', 'like', "%{$input}%")
    ->orWhere('desc', 'like', "%{$input}%")
    ->orWhere('content', 'like', "%{$input}%");

# 关联关系

如果安装了 dcat/laravel-wherehasin (opens new window),则会优先使用whereHasIn方法进行查询操作

$grid->quickSearch('user.name', 'user.username', 'content');

# 自定义搜索

第二种方式可以让你更灵活的控制搜索条件

$grid->quickSearch(function ($model, $query) {
    $model->where('title', $query)->orWhere('desc', 'like', "%{$query}%");
});

其中闭包的参数$query为你填入搜索框中的内容,提交之后进行闭包中的查询。

# 快捷语法搜索

第三种方式参考了Github的搜索语法,来进行快捷搜索,调用方式:

// 不传参数
$grid->quickSearch();

填入搜索框的内容按照以下的语法,在提交之后会进行相应的查询 :

# 比较查询

title:foo 、title:!foo

$model->where('title', 'foo');

$model->where('title', '!=', 'foo');

rate:>10、rate:<10、rate:>=10、rate:<=10

$model->where('rate', '>', 10);

$model->where('rate', '<', 10);

$model->where('rate', '>=', 10);

$model->where('rate', '<=', 10);

# In、NotIn查询

status:(1,2,3,4)、status:!(1,2,3,4)

$model->whereIn('status', [1,2,3,4]);

$model->whereNotIn('status', [1,2,3,4]);

# Between查询

score:[1,10]

$model->whereBetween('score', [1, 10]);

# 时间日期函数查询

created_at:date,2019-06-08

$model->whereDate('created_at', '2019-06-08');

created_at:time,09:57:45

$model->whereTime('created_at', '09:57:45');

created_at:day,08

$model->whereDay('created_at', '08');

created_at:month,06

$model->whereMonth('created_at', '06');

created_at:year,2019

$model->whereYear('created_at', '2019');

# Like查询

content:%Laudantium%、content:Laud%

$model->where('content', 'like', '%Laudantium%');

$model->where('content', 'like', 'Laud%');

# 正则查询

username:/song/

提示

这里请使用MYSQL正则语法

$model->where('username', 'REGEXP', 'song');

# 多条件组合搜索

用空格隔开多个搜索语句就可以实现多个字段的AND查询,比如username:%song% status:(1,2,3), 提交之后会运行下面的搜索

$model->where('username', 'like', '%song%')->whereIn('status', [1, 2, 3]);

如果某一个条件是OR查询, 只需要在语句单元前增加一个|符号即可: username:%song% |status:(1,2,3)

$model->where('username', 'like', '%song%')->orWhereIn('status', [1, 2, 3]);

提示

如果填入的查询文字中包含空格,需要放在双引号里面:updated_at:"2019-06-08 09:57:45"

# Label作为查询字段名称

不方便得到字段名的情况下,可以直接使用label名称作为查询字段

 // 比如设置了`user_status`的表头列名为`用户状态`
$grid->column('user_status', '用户状态');

那么可以填入用户状态:(1,2,3)来执行下面的查询

$model->whereIn('user_status', [1, 2, 3]);

# 禁止自动提交

快捷搜索默认是开启自动提交功能的,如果你不需要自动提交,可以通过以下方式禁用这个功能

提示

禁用了自动提交功能之后需要通过按回车(Enter)键进行搜索。

$grid->quickSearch()->auto(false);
列过滤器
表格规格筛选器

← 列过滤器 表格规格筛选器→

Theme by Vdoing | Copyright © 2020-2022 wyz.xyz 宁ICP备15001739号-5
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
×