easyui combogrid实现本地模糊搜索过滤多列


Posted in Javascript onMay 13, 2017

这几天在项目中前台使用到了easyui 的 combogrid插件为用户提供点选数据项的功能。由于数据项的内容可能有很多,所以仅仅是点选还不够,需要能够对用户的输入进行过滤,即根据用户的输入将某一列与用户输入匹配的数据项筛选保留下来。

实现这一功能需要以下几个步骤:

1.声明一个combogrid

<div class="fitem"> 
      <label>盘条基本信息编号:</label> 
      <input class="easyui-combogrid" type="text" id="addWireRodId" name="wireRodId" style="width: 150px" 
          data-options="required:true"></input> 
</div>

2.js中请求combogrid需要加载的数据

var wireRod; 
    $.ajax({ 
      url: "../wireRod/getAll?rows=100000&sort=id&order=asc", 
      type: "post", 
      dataType: "json", 
      success: function (result) { 
        wireRod = result.wireRod.list; 
      } 
});

3.对combogrid进行配置

$("#addWireRodId").combogrid({ 
      idField:'id', 
      textField:'codeDesc', 
      remoteSort: false, 
      panelWidth: 360, 
      columns: [[ 
        {field: 'codeDesc', title: '盘条序号', sortable: true, width: 70}, 
        {field: 'code', title: '盘条编码'}, 
        {field: 'name', title: '盘条名称'}, 
        {field: 'specification', title: '盘条规格'}, 
      ]], 
      onSelect: function (index,row) { 
        //业务功能,不予展示 
      }, 
      onChange: function (q){ 
        doSearch(q,wireRod,['codeDesc','code','name','specification'],$(this)); 
      }, 
      onShowPanel:function () { 
          $(this).combogrid('grid').datagrid('loadData', wireRod); 
      } 
    });

4.doSearch方法

//q为用户输入,data为远程加载的全部数据项,searchList是需要进行模糊搜索的列名的数组,ele是combogrid对象 
//doSearch的思想其实就是,进入方法时将combogrid加载的数据清空,如果用户输入为空则加载全部的数据,输入不为空 
//则对每一个数据项做匹配,将匹配到的数据项加入rows数组,相当于重组数据项,只保留符合筛选条件的数据项, 
//如果筛选后没有数据,则combogrid加载空,有数据则重新加载重组的数据项 
function doSearch(q,data,searchList,ele){ 
    ele.combogrid('grid').datagrid('loadData', []); 
    if(q == ""){ 
      ele.combogrid('grid').datagrid('loadData', data); 
      return; 
    } 
    var rows = []; 
    $.each(data,function(i,obj){ 
      for(var p in searchList){ 
        var v = obj[searchList[p]]; 
        if (!!v && v.toString().indexOf(q) >= 0){ 
          rows.push(obj); 
          break; 
        } 
      } 
    }); 
    if(rows.length == 0){ 
      ele.combogrid('grid').datagrid('loadData', []); 
      return; 
    } 
    ele.combogrid('grid').datagrid('loadData', rows); 
  }

combogrid有两种mode,local和remote,默认为local,其实remote mode也可以做多列模糊搜索,因为它会向后台发送一个包含叫做‘q'的参数的http请求以请求过滤后的数据,但是这样的不好在于,明明我们已经向后台请求过一次全部的数据,为什么还要再多次请求过滤的数据呢,服务器的负载会加重,所以这种事情能在前端做了就挺好

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
简单的无缝滚动程序-仅几行代码
May 08 Javascript
Javascript 读书笔记索引贴
Jan 11 Javascript
自己编写的类似JS的trim方法
Oct 09 Javascript
jQuery设置和获取HTML、文本和值示例
Jul 08 Javascript
初步了解javascript面向对象
Nov 09 Javascript
SpringMVC返回json数据的三种方式
Dec 10 Javascript
js实现的页面矩阵图形变换特效
Jan 26 Javascript
Vue中render函数的使用方法
Jan 31 Javascript
jQuery时间戳和日期相互转换操作示例
Dec 07 jQuery
微信小程序实现日历效果
Dec 28 Javascript
如何写好一个vue组件,老夫的一年经验全在这了(推荐)
May 18 Javascript
一篇文章看懂JavaScript中的回调
Jan 05 Javascript
web.js.字符串与正则表达式操作
May 13 #Javascript
JS实现动态给标签控件添加事件的方法示例
May 13 #Javascript
jQuery插件FusionCharts绘制的2D条状图效果【附demo源码】
May 13 #jQuery
jQuery插件FusionCharts绘制的2D双柱状图效果示例【附demo源码】
May 13 #jQuery
vue.js 初体验之Chrome 插件开发实录
May 13 #Javascript
JS中cookie的使用及缺点讲解
May 13 #Javascript
jQuery中clone()函数实现表单中增加和减少输入项
May 13 #jQuery
You might like
优化PHP程序的方法小结
2012/02/23 PHP
PHP时间戳与日期之间转换的实例介绍
2013/04/19 PHP
php实现监听事件
2013/11/06 PHP
PHP中的traits实现代码复用使用实例
2015/05/13 PHP
php微信公众号开发(3)php实现简单微信文本通讯
2016/12/15 PHP
laravel 出现command not found问题的解决方案
2019/10/23 PHP
PHP字符串与数组处理函数用法小结
2020/01/07 PHP
Jquery Ajax.ashx 高效分页实现代码
2009/10/20 Javascript
js 点击按钮弹出另一页,选择值后,返回到当前页
2010/05/26 Javascript
电子商务网站上的常用的js放大镜效果
2011/12/08 Javascript
《JavaScript高级程序设计》阅读笔记(三) ECMAScript中的引用类型
2012/02/27 Javascript
js类定义函数时用prototype与不用的区别示例介绍
2014/06/10 Javascript
详解AngularJS中自定义指令的使用
2015/06/17 Javascript
node.js版本管理工具n无效的原理和解决方法
2016/11/24 Javascript
简单实现jquery焦点图
2016/12/12 Javascript
详解照片瀑布流效果(js,jquery分别实现与知识点总结)
2017/01/01 Javascript
微信小程序模板和模块化用法实例分析
2017/11/28 Javascript
nodejs 生成和导出 word的实例代码
2018/07/31 NodeJs
详解使用angular框架离线你的应用(pwa指南)
2019/01/31 Javascript
uni-app微信小程序登录授权的实现
2020/05/22 Javascript
vue 如何使用递归组件
2020/10/23 Javascript
[38:39]KG vs Mineski 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
python 如何将office文件转换为PDF
2020/09/22 Python
Sneaker Studio捷克:购买运动鞋
2018/07/08 全球购物
Cult Gaia官网:美国生活方式品牌
2019/08/16 全球购物
党员入党表决心的话
2014/03/11 职场文书
电子工程专业毕业生求职信
2014/03/14 职场文书
元宵节主持词
2014/03/25 职场文书
事业单位考核材料
2014/05/21 职场文书
ktv好的活动方案
2014/08/15 职场文书
2016高中社会实践心得体会范文
2016/01/14 职场文书
Mysql案例刨析事务隔离级别
2021/09/25 MySQL
分享7个 Python 实战项目练习
2022/03/03 Python
Java 垃圾回收超详细讲解记忆集和卡表
2022/04/08 Java/Android
i5-10400f处理相当于i7多少水平
2022/04/19 数码科技
深入理解 Golang 的字符串
2022/05/04 Golang