Portal的Keywords Widget无法自动重置filter怎么办
更新:HHH   时间:2023-1-7


这篇文章主要为大家展示了“Portal的Keywords Widget无法自动重置filter怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Portal的Keywords Widget无法自动重置filter怎么办”这篇文章吧。

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

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

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

如何解决这个问题呢?

我们首先找到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的搜索效果了。

以上是“Portal的Keywords Widget无法自动重置filter怎么办”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注天达云行业资讯频道!

返回web开发教程...