当前位置 : 主页 > 网页制作 > Dojo >

对Dgrid表格进行模糊搜索

来源:互联网 收集:自由互联 发布时间:2021-06-15
最近在使用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)
网友评论