有没有办法替换 HTML 主体内的表格元素内的普通文本?比如将“hello”替换为“hi”?请仅使用 JavaScript,不要使用 jQuery。
有没有办法可以替换 HTML 主体内的表格元素内的普通文本?
比如将 \'hello\' 替换为 \'hi\'?
请仅使用 JavaScript ,不带 jQuery .
下面的功能对我来说非常有效:
// Note this *is* JQuery, see below for JS solution instead
function replaceText(selector, text, newText, flags) {
var matcher = new RegExp(text, flags);
$(selector).each(function () {
var $this = $(this);
if (!$this.children().length)
$this.text($this.text().replace(matcher, newText));
});
}
以下是一个使用示例:
function replaceAllText() {
replaceText('*', 'hello', 'hi', 'g');
}
$(document).ready(replaceAllText);
$('html').ajaxStop(replaceAllText);
您也可以像这样直接替换:
document.body.innerHTML = document.body.innerHTML.replace('hello', 'hi');
但要小心,因为它也可能会影响标签、CSS 和脚本。
编辑: 对于纯 JavaScript 解决方案,请改用此方法:
function replaceText(selector, text, newText, flags) {
var matcher = new RegExp(text, flags);
var elems = document.querySelectorAll(selector), i;
for (i = 0; i < elems.length; i++)
if (!elems[i].childNodes.length)
elems[i].innerHTML = elems[i].innerHTML.replace(matcher, newText);
}