Ale*_*lec 5 regex jquery autocomplete highlighting
我正在使用jQuery Autocomplete插件,但我在结果突出显示时遇到了一些问题.找到匹配项但输入的关键字包含空格时,没有突出显示.例:
search ="foo",result ="foo bar",显示=" foo bar"
search ="foo ba",result ="foo bar",显示="foo bar"
所以,我正在尝试使用自动完成功能的高亮选项来修复此问题,您可以使用该功能对结果执行一些自定义操作.目前我有这个:
$('.autocomplete').autocomplete('getmatch.php', {
highlight: function(match, keywords) {
keywords = keywords.split(' ').join('|');
return match.replace(/(get|keywords|here)/gi,'<b>$1</b>');
}
});
replace函数用粗体版本替换字符串中所有匹配的单词,这是有效的.但是,我不知道如何将关键字放入该功能.我虽然将它们分开,然后用'|'加入它们,所以"foo bar"最终会像"foo | bar"一样.但这样的事情似乎不起作用:
Run Code Online (Sandbox Code Playgroud)return match.replace(/(keywords)/gi,'<b>$1</b>'); // seen as text, I think
Run Code Online (Sandbox Code Playgroud)return match.replace('/'+(keywords)+'/gi','<b>$1</b>'); // nothing either
有任何想法吗?
Gum*_*mbo 11
使用RegExp
构造函数从字符串创建RegExp对象:
$('.autocomplete').autocomplete('getmatch.php', {
highlight: function(match, keywords) {
keywords = keywords.split(' ').join('|');
return match.replace(new RegExp("("+keywords+")", "gi"),'<b>$1</b>');
}
});
Run Code Online (Sandbox Code Playgroud)