[whatwg] DOM Range: redefining behavior under DOM mutation

Boris Zbarsky bzbarsky at MIT.EDU
Tue Mar 29 11:43:24 PDT 2011


On 3/29/11 2:37 PM, Boris Zbarsky wrote:
>> That already has to happen for
>> insertData()/deleteData()/appendData(), right? All browsers treat
>> those differently from just setting the data to the equivalent
>> string.
>
> Those map directly to atomic operations on CharacterData, for what it's
> worth.

Oh, I see; I had misunderstood what you were saying, so didn't quite 
answer your question.

The point is, these operations are atomic, so there is no DOM-visible 
intermediate state.  In Gecko's case, there is an internal 
CharacterDataChanged notification, which is passed the following 
information:

1)  Position of change start in the CharacterData node's text.
2)  Length of removed text starting at that position (can be 0).
3)  Length of inserted text starting at that position (can be 0).

Given all three pieces of information, it's easy to adjust the range 
endpoints in a "sensible" way.

Note that technically that behavior is a violation of DOM2 Range, but 
that's what we're trying to replace, right?

-Boris



More information about the whatwg mailing list