【发布时间】:2010-10-31 17:29:24
【问题描述】:
我正在使用 jQuery Autocomplete plugin,但我在结果突出显示方面遇到了一些问题。如果找到匹配项,但输入的关键字包含空格,则不会突出显示。示例:
搜索 = "foo",结果 = "foo bar",显示 = "foo bar"
搜索 = “foo ba”,结果 = “foo bar”,显示 = “foo bar”
所以,我正在尝试使用自动完成功能的highlight option 来解决此问题,您可以在其中使用函数对结果执行一些自定义操作。目前我有这个:
$('.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”。但是这样的事情似乎不起作用:
<pre>return match.replace(/(keywords)/gi,'<b>$1</b>'); // seen as text, I think</pre>
<pre>return match.replace('/'+(keywords)+'/gi','<b>$1</b>'); // nothing either</pre>
有什么想法吗?
【问题讨论】:
标签: jquery regex autocomplete highlighting