这篇文章主要为大家展示了“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怎么办”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注天达云行业资讯频道!