Я пытаюсь заменить каждое появление слова новым содержимым HTML. Я попытался это:Заменить каждое появление слова новым содержимым HTML
function walk(node) {
var child, next;
switch (node.nodeType) {
case 1: // Element
case 9: // Document
case 11: // Document fragment
child = node.firstChild;
while (child) {
next = child.nextSibling;
walk(child);
child = next;
}
break;
case 3: // Text node
handleText(node);
break;
}
}
function handleText(textNode) {
var v = textNode.nodeValue;
var replacement = "<h1>foo</h1>";
v = v.replace(/toReplace/g, replacement);
textNode.nodeValue = v;
}
walk(document.body);
То, что я хочу, чтобы заменить все toReplace
текст с новым содержанием фактической HTML (а foo
в h1), но это только в буквальном смысле печатает ставить <h1>foo</h1>
Fiddle: http://jsfiddle.net/7zkY8/
Как я могу это исправить?
Вы не можете поместить HTML в текстовый узел и ожидать, что он будет обработан как HTML. Это текстовый узел - он отображает только текст, а не HTML. Вам придется заменить текстовый узел на элемент DOM (возможно, элемент ''). – jfriend00