I have a scenario where I need to split a node up to a given ancestor, e.g.
<strong>hi there, how <em>are <span>you</span> doing</em> today?</strong>
needs to be split into:
<strong>hi there, how <em>are <span>y</span></em></strong>
and
<strong><em><span>ou</span> doing</em> today?</strong>
How would I go about doing this?
Here is a solution that will work for modern browsers using
Range. Something similar could be done for IE < 9 usingTextRange, but I use Linux so I don’t have easy access to those browsers. I wasn’t sure what you wanted the function to do, return the nodes or just do a replace inline. I just took a guess and did the replace inline.Demo: jsbin
It expects a
TextNodefornode, although it will work with anElement; the offset will just function differently based on the behavior of Range.setStart