【发布时间】:2011-08-08 19:13:50
【问题描述】:
我想在我的网页上找到与 Javascript 数组中的任何单词匹配的所有单词,并突出显示它们(将它们包装在特殊的 span 标签中)。最简单的方法是什么?我使用 jquery。
【问题讨论】:
-
不是重复的。大多数其他问题与如何匹配给定大小写有关,而不是数组。
标签: jquery
我想在我的网页上找到与 Javascript 数组中的任何单词匹配的所有单词,并突出显示它们(将它们包装在特殊的 span 标签中)。最简单的方法是什么?我使用 jquery。
【问题讨论】:
标签: jquery
并不完美,但很简单,可能会奏效:
var regex = /(Hello|Goodbye)/g;
$('*').each(function() {
var $this = $(this);
var text = $this.text();
if (regex.test(text)) {
$this.html(
$this.html().replace(regex, '<span>$1</span>')
);
}
});
【讨论】:
var wordsToReplace = /(\bof\b|\bour\b|\bfrom\b|\bto\b|\bat\b)/gi;Ugly,但它可以完成工作。
试试这些方法
highlightWord(["text1", "text2"]);
function highlightWord(searchArray, container)
{
var bodyText;
if(container)
bodyText = container.html();
else
bodyText = $(document.body).html();
container = container || $(document.body);
for (var i = 0; i < searchArray.length; i++) {
bodyText = doHighlight(bodyText, searchArray[i]);
}
container.html(bodyText);
return true;
}
function doHighlight(bodyText, searchTerm)
{
var highlightStartTag = "<span style='color:blue; background-color:yellow;'>";
var highlightEndTag = "</span>";
var newText = "";
var i = -1;
var lcSearchTerm = searchTerm.toLowerCase();
var lcBodyText = bodyText.toLowerCase();
while (bodyText.length > 0) {
i = lcBodyText.indexOf(lcSearchTerm, i+1);
if (i < 0) {
newText += bodyText;
bodyText = "";
} else {
if (bodyText.lastIndexOf(">", i) >= bodyText.lastIndexOf("<", i)) {
if (lcBodyText.lastIndexOf("/script>", i) >= lcBodyText.lastIndexOf("<script", i)) {
newText += bodyText.substring(0, i) + highlightStartTag + bodyText.substr(i, searchTerm.length) + highlightEndTag;
bodyText = bodyText.substr(i + searchTerm.length);
lcBodyText = bodyText.toLowerCase();
i = -1;
}
}
}
}
return newText;
}
【讨论】: