javascript - 如何使用 Javascript 替换 HTML 页面中出现的所有字符串

标签 javascript string replace

我知道以前可能有人问过这个问题,但我没有找到有效的正确答案。

我试过这段代码

$('body *').each(function(k,v){$(v).text($(v).text().replace("Hazem","mizzo"))});

但是页面崩溃了,我不知道为什么。

我更喜欢使用纯 javascript 而不是 jQuery 的代码。 谢谢。

最佳答案

您应该遍历 DOM,查找文本节点,并替换每个节点中找到的文本。

这是一个简单的例子。您可以通过传递执行替换的回调来使 walkText() 更通用。

function walkText(node) {
  if (node.nodeType == 3) {
    node.data = node.data.replace(/foo/g, "bar");
  }
  if (node.nodeType == 1 && node.nodeName != "SCRIPT") {
    for (var i = 0; i < node.childNodes.length; i++) {
      walkText(node.childNodes[i]);
    }
  }
}
walkText(document.body);
foo <b>foo</b> foo

关于javascript - 如何使用 Javascript 替换 HTML 页面中出现的所有字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34559256/

相关文章:

javascript - 如何让 "createElement"不重复,而是用新信息替换旧信息?

jquery - 使用jquery将<br>替换为空格

javascript - 如果 php 变量链接为空,则禁用 href 标签

javascript - 当多选选项设置为 true 时,为复选框列添加自定义格式化程序

java - 如何对正则表达式取反

Java从运行时获取特定行?

java - 如何检查数组是否包含字符串中的特定单词并获取它?

javascript - 如何在 v-html 之间切换并在 vue.js 中以纯文本形式插入?

javascript - 无法将 javascript 文件作为电子邮件附件发送

python - 最有效的字符串相似度度量函数