最近在使用Dojo的拓展插件Dgrid时,需要做到一个功能——对Dgrid表格中的内容进行模糊搜索,弄了老半天也是将这个搞了出来。 昨天把模糊搜索的代码抽出来,并整理了一下。这段代码
最近在使用Dojo的拓展插件Dgrid时,需要做到一个功能——对Dgrid表格中的内容进行模糊搜索,弄了老半天也是将这个搞了出来。
昨天把模糊搜索的代码抽出来,并整理了一下。这段代码在逻辑上清晰易懂很多,毕竟要给项目组的其他人用。下面贴码。
var common = { /** * @example commom.onQuery(oInput, oGrid, aInitialData); * @description 模糊查询,在输入框输入任意值即可对表格内容进行搜索,模糊搜索的效果可参考百度的搜索。使用:(1)dgrid表格startup后,调用此函数。(2)当表格数据刷新时,需要重新调用此函数。 * @param {Object} oS input框对象,即用来进行搜索的输入框 * @param {Object} grid Dgrid表格对象 * @param {Array} initialData 表格的初始数据 * */ onQuery: function(oS, grid, initialData) { var _; oS.oldLength = 0, _ = { name: "模糊搜索主体函数", searchTimeout: null,//这个变量用来设置延时,减少dgrid的刷新次数。 //模糊搜索的入口。 onQuery: function() { if(oS.value != "") {//搜索框的输入值增多 if(oS.value.length > oS.oldLength) {//搜索框的输入值增多,进行增值搜索。 _._queryMore(); } else if(oS.value.length < oS.oldLength) {//搜索框的输入值减少,进行减值搜索。 _._queryLess(); } } else {//搜索框的输入值为空,进行空值搜索。 _._queryNull(); } //将当前input值的长度赋值给 oS.oldLength。 oS.oldLength = oS.value.length; }, //将输入框的输入值切割为数组,并去除值为 "" 的空值。将整理完的筛选条件数组返回。 _aGetFilter: function() { //清除查询条件多余的空格 var aV = oS.value.replace(/\s+/g, " ").split(" "); //删除筛选条件数组的空元素 for(var i = 0; i < aV.length; i++) { if(aV[i].length == 0 || aV[i] === "") { aV.splice(i, 1); } } return aV; }, _queryNull: function() { _._refreshData(); }, _queryMore: function(aV) { var temp = null, aV = _._aGetFilter(); for(var i = 0, iL = aV.length; i < iL; i++) { //返回匹配出来的数据。 temp = grid.store.query(function(object) { return object.name.indexOf(aV[i]) >= 0; }); } //将搜索结果放入表格中,更新表格。 _._updateData(temp); }, _queryLess: function() { var temp = null, aV = _._aGetFilter(); //重置表格数据。 _._resetData(); for(var i = 0, iL = aV.length; i < iL; i++) { //返回匹配出来的数据。 temp = grid.store.query(function(object) { return object.name.indexOf(aV[i].replace(/\s+/g, "")) >= 0;//对表格中每一行数据的name进行搜索。 }); } //将搜索结果放入表格中,更新表格。 _._updateData(temp); }, _updateData: function(temp) { //设置延时器,减少dgrid表格的setData、refresh方法的执行次数,提高搜索性能、搜索体验。 _.searchTimeout && clearTimeout(_.searchTimeout); _.searchTimeout = setTimeout(function() { grid.store.setData(temp); grid.refresh();//刷新dgrid表格,展示搜索结果。 }, 100); }, _resetData: function() { //重置表格数据为初始值,因为是立即重置,所以不加入定时器。 grid.store.setData(initialData); }, _refreshData: function() { //这个方法为刷新表格数据位初始值,需要加入延时器(延时器在_._updateData方法中),防止此方法多次执行。 _._updateData(initialData); } }; //当输入框的值发生改变时,调用模糊搜索入口执行方法_.onQuery。因为考虑不同浏览器的兼容问题,所以这么写。前面兼容IE,后面谷歌火狐等。 document.all ? oS.onpropertychange = _.onQuery : oS.addEventListener("input", _.onQuery, false); } }使用方法很简单,照着注释里的来就行。
commom.onQuery(this.search, this.grid, this.initialData)