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