If I have this:
<a href="#" id="the-link"><em>any random text</em></a>
Or this:
<a href="#" id="the-link">any random text</a>
Or this:
<a href="#" id="the-link"><em><div id="foo"><span>any random text</span></div></em></a>
I would like to capture the text "any random text" and then replace it.
How can I do this with jQuery? If not with jQuery, just regular javascript?
You could do this recursively. It's pretty simple:
function replaceTextNodes(node, newText) {
if (node.nodeType == 3) {
// Filter out text nodes that contain only whitespace
if (!/^\s*$/.test(node.data)) {
node.data = newText;
}
} else if (node.hasChildNodes()) {
for (var i = 0, len = node.childNodes.length; i < len; ++i) {
replaceTextNodes(node.childNodes[i], newText);
}
}
}
replaceTextNodes(document.getElementById("the-link"), "NEW TEXT");
$('a:contains(starcraft)').html('starcraft 2');
Edit for comment: jsfiddle
$('a').find(':only-child:last').html('starcraft 2');
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With