DOM と.replace()
テキスト ノードの値をウォークします。
function walk(el, fn) {
for (var i = 0, len = el.childNodes.length; i < len; i++) {
var node = el.childNodes[i];
if (node.nodeType === 3)
fn(node);
else if (node.nodeType === 1 && node.nodeName !== "SCRIPT")
walk(node, fn);
}
}
walk(document.body, function(node) {
var text = node.data.split("foo"),
parent = node.parentNode,
i = 1,
newNode;
parent.insertBefore(textNode(text[0]), node);
for (; i < text.length; i += 2) {
(newNode = document.createElement("b"))
.appendChild(textNode("bar"));
parent.insertBefore(newNode, node);
parent.insertBefore(textNode(text[i]), node);
}
parent.removeChild(node);
});
function textNode(txt) {
return document.createTextNode(txt);
}