【问题标题】:How do you highlight all the words on the page that match an array of words?如何突出显示页面上与一组单词匹配的所有单词?
【发布时间】:2011-08-08 19:13:50
【问题描述】:

我想在我的网页上找到与 Javascript 数组中的任何单词匹配的所有单词,并突出显示它们(将它们包装在特殊的 span 标签中)。最简单的方法是什么?我使用 jquery。

【问题讨论】:

标签: jquery


【解决方案1】:

并不完美,但很简单,可能会奏效:

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>')
        );
    }
});

http://jsfiddle.net/pdWAn/

【讨论】:

  • 很棒的答案。我使用修改后的正则表达式来: 1. 最后忽略大小写“i”。 2. 只匹配单独的单词。例如,如果文本包含单词“to”和“history”,则搜索“to”将被找到。我通过在每个单词前后添加“\b”来解决这个问题。以完整的正则表达式为例:var wordsToReplace = /(\bof\b|\bour\b|\bfrom\b|\bto\b|\bat\b)/gi;Ugly,但它可以完成工作。
【解决方案2】:

试试这些方法

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;
}

【讨论】:

  • 是的,我们可以指定要突出显示文本的容器,而不是 bodyText。
  • @dan - 请检查我编辑的答案,现在它需要在其中搜索单词的容器。
  • @dan - 你有机会试试这个吗?
  • 谢谢。我喜欢上面较短的答案,因为它很短,但我会投票赞成你的答案,因为你花时间帮助我。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2016-11-30
  • 2020-05-28
  • 2015-06-10
  • 2015-11-14
  • 2015-03-07
  • 1970-01-01
  • 2020-11-27
相关资源
最近更新 更多