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 相关文章推荐
JavaScript 原型学习总结
Oct 29 Javascript
range 标准化之获取
Aug 28 Javascript
jQuery中jqGrid分页实现代码
Nov 04 Javascript
javascript之Partial Application学习
Jan 10 Javascript
js中将String转换为number以便比较
Jul 08 Javascript
innerHTML在IE中报错解决方案
Dec 15 Javascript
JS定义网页表单提交(submit)的方法
Mar 20 Javascript
jQuery Ajax页面局部加载方法汇总
Jun 02 Javascript
深入理解JavaScript中的并行处理
Sep 22 Javascript
JavaScript使用Math.random()生成简单的验证码
Jan 21 Javascript
vuex管理状态 刷新页面保持不被清空的解决方案
Nov 11 Javascript
JS+HTML5本地存储Localstorage实现注册登录及验证功能示例
Feb 10 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下获取客户端ip地址的函数
2010/03/15 PHP
Smarty Foreach 使用说明
2010/03/23 PHP
jQuery向下滚动即时加载内容实现的瀑布流效果
2016/01/07 PHP
PHPCrawl爬虫库实现抓取酷狗歌单的方法示例
2017/12/21 PHP
PHP PDOStatement::execute讲解
2019/01/31 PHP
延时重复执行函数 lLoopRun.js
2007/05/08 Javascript
用jquery实现的模拟QQ邮箱里的收件人选取及其他效果(一)
2011/01/06 Javascript
基于jquery实现拆分姓名的方法(纯JS版)
2013/05/08 Javascript
JavaScript实现表格排序方法
2013/06/14 Javascript
图片翻转效果具体实现代码
2014/01/09 Javascript
Javascript 按位与赋值运算符 (&amp;=)使用介绍
2014/02/04 Javascript
使用AngularJS和PHP的Laravel实现单页评论的方法
2015/06/19 Javascript
JavaScript继承模式粗探
2016/01/12 Javascript
Vuejs第十篇之vuejs父子组件通信
2016/09/06 Javascript
jQuery插件ajaxFileUpload使用实例解析
2016/10/19 Javascript
原生js验证简洁注册登录页面
2016/12/17 Javascript
详解React开发必不可少的eslint配置
2018/02/05 Javascript
React Native悬浮按钮组件的示例代码
2018/04/05 Javascript
vue中设置height:100%无效的问题及解决方法
2018/07/27 Javascript
JavaScript原型链与继承操作实例总结
2018/08/24 Javascript
vue webpack开发访问后台接口全局配置的方法
2018/09/18 Javascript
JS实现的tab页切换效果完整示例
2018/12/18 Javascript
[01:14:55]EG vs Spirit Supermajor 败者组 BO3 第三场 6.4
2018/06/05 DOTA
使用Python脚本来控制Windows Azure的简单教程
2015/04/16 Python
详解Python中的Cookie模块使用
2015/07/06 Python
python中的tcp示例详解
2018/12/09 Python
关于numpy中eye和identity的区别详解
2019/11/29 Python
html5 利用canvas手写签名并保存的实现方法
2018/07/12 HTML / CSS
跨域修改iframe页面内容详解
2019/10/31 HTML / CSS
Original Penguin美国官网:布拉德皮特、强尼德普喜爱的服装品牌
2016/10/25 全球购物
服装设计师职业生涯规划范文
2014/02/28 职场文书
政府绩效管理实施方案
2014/05/04 职场文书
入党介绍人意见范文
2015/06/01 职场文书
小学运动会入场口号
2015/12/24 职场文书
怎样写工作总结啊!
2019/06/18 职场文书
CSS实现章节添加自增序号的方法
2021/06/23 HTML / CSS