Bug 56706

Summary: DOMNodeRemovedFromDocument (capture phase) not fired for innerHTML update
Product: WebKit Reporter: Luke Smith <lsmith>
Component: DOMAssignee: Nobody <webkit-unassigned>
Status: RESOLVED WONTFIX    
Severity: Normal CC: annevk, ap, kevin.cs.oh, rniwa
Priority: P3    
Version: 528+ (Nightly build)   
Hardware: Mac (Intel)   
OS: OS X 10.5   
URL: http://lucassmith.name/pub/browser_bugs/wk/domnoderemovedfromdocument_bug.html

Luke Smith
Reported 2011-03-18 23:26:44 PDT
Capture phase subscribers to DOMNodeRemovedFromDocument are executed for each descendant node that is removed, including text nodes, in most cases. The one case that I have found where this is not true is when an element contains only text (I didn't test an element containing exclusively multiple text nodes). Given the markup below: <p>This will not trigger the callback</p> <p>But this <em>will</em></p> A capture phase subscriber on each p for DOMNodeRemovedFromDocument should fire when that paragraph element's innerHTML is assigned. This is only true for the second paragraph. However, calling replaceChild(document.createTextNode('new text'), firstChild) will trigger the callback for the first paragraph. Opera 11 implements this event and executes the callback consistently for innerHTML assignments regardless of the presence of child elements.
Attachments
Luke Smith
Comment 1 2011-03-18 23:27:49 PDT
Simplified repro case at the url provided.
Anne van Kesteren
Comment 2 2023-12-29 02:55:01 PST
We're not interested in improving mutation events.
Note You need to log in before you can comment on or make changes to this bug.