ServiceNow portal端的开箱表格组件支持Keywords搜索功能。


ServiceNow前台Portal和后台都是支持keywords搜索的(for text, query filter is '123TEXTQUERY321='+keywords)



但是有个问题就是,在portal端每一次keywords search后系统没有清除上一次的keywords filter。也就是说第二次的keywords搜索是在第一次的keywords搜索的基础上进行的。(除非点击刷新页面的按钮,这样操作感觉很不友好哇)

Capture.PNG


如何解决这个问题呢?


我们首先找到portal page中table对应的widget my Table(本例中使用的my Table  is copy from Data Table)。


widget中关于keywords的搜索filter的设置在Server script中:我在代码上添加注释说明


if (data.filter) {
    if (data.filterACLs)
        gr = $sp.addQueryString(gr, data.filter);
    else
        gr.addEncodedQuery(data.filter);
}
if (data.keywords){
    gr.addQuery('123TEXTQUERY321', data.keywords);//添加keywords查询语句filter到table
    data.keywords = null;                         //每次输入keywords查询后,输入框的内容会被自动清空
}

这段开箱的代码会把每次输入的keywords添加到查询的filter,果然没有清除已经存在的上一次输入的keywords的filter。


So 知道了原因,fix方案就很简单了,下面提供一种方案(若有其他更优解或改进处欢迎留言) :

	var keyWordsIndex = 0;
	if (data.filter) {
	        //判断已有的data.filter里是否已经存在keywords的filter,如果存在就移除
		keyWordsIndex = data.filter.indexOf('^123TEXTQUERY321');
		if(keyWordsIndex > 0){
			data.filter = data.filter.slice(0,keyWordsIndex);
		}
		
	}
	if (data.keywords){
	        //通过filter str添加方法替换开箱的addQuery方法。
		if (data.filter) {
			data.filter += '^123TEXTQUERY321='+data.keywords;
		}
		else {
			data.filter += '123TEXTQUERY321='+data.keywords;			
		}
		data.keywords = null;
	}
	
	//after creating new filter add the query filter to table
	if (data.filterACLs)
		gr = $sp.addQueryString(gr, data.filter);
	else
		gr.addEncodedQuery(data.filter);

经过上面的处理后,就能实现如后台一样每次都只会重置keywords filter的搜索效果了。