[Webkit-unassigned] [Bug 149251] New: IFrame contentWindow loses add/remove eventListener methods when its not in the DOM
bugzilla-daemon at webkit.org
bugzilla-daemon at webkit.org
Thu Sep 17 00:45:55 PDT 2015
https://bugs.webkit.org/show_bug.cgi?id=149251
Bug ID: 149251
Summary: IFrame contentWindow loses add/remove eventListener
methods when its not in the DOM
Classification: Unclassified
Product: WebKit
Version: Safari 8
Hardware: Unspecified
OS: Unspecified
Status: NEW
Severity: Normal
Priority: P2
Component: Frames
Assignee: webkit-unassigned at lists.webkit.org
Reporter: AmazingJaze at gmail.com
Hello,
I have found that on Safari and iOS, if I add a resize listener to the contentWindow of an Iframe, then I am unable to remove that listener if the Iframe is no longer in the DOM. I am concerned about memory leaks.
The Iframe contentWindow property returns null when it is not in the DOM and if I had previously stored a reference to the Iframe's contentWindow property before it was removed from the
DOM, checking that reference while the iframe is not in the DOM returns a Window object that is missing all the methods from its prototype chain, such as addEventListener and removeEventListener.
I am writing a UI control that creates and uses an Iframe and its "resize" event. I try to unregister my resize listener on the Iframe contentWindow whenever a user calls my control's dispose() API, but there is no way to guarantee that the control is still in the DOM when this happens, and if its not in the DOM, an exception is thrown.
Below is a very simple repro. This does not Repro in Chrome, IE, Edge, FF, or Android browser.
var iframe = document.createElement("IFRAME");
var referenceToContentWindow;
document.body.appendChild(iframe);
setTimeout(function () {
referenceToContentWindow = iframe.contentWindow;
// Evaluates to True
!!iframe.contentWindow.removeEventListener
// Evaluates to True
!!referenceToContentWindow.removeEventListener
document.body.removeChild(iframe);
setTimeout(function () {
// Throws Exception, contentWindow is null
!!iframe.contentWindow.removeEventListener
// Evaluates to False, referenceToContentWindow is type Window, but it no longer has the function.
!!referenceToContentWindow.removeEventListener
}, 100);
}, 100);
As a work around I tried calling:
Object.getPrototypeOf(referenceToContentWindow).removeEventListener.call(referenceToContentWindow, "resize", boundResizeHandler);
And while that executes without throwing a DOM exception, it doesn't actually remove the handler, as it will still fire if I re-append the iframe and resize it, but running the above line while the Iframe is already in the DOM, will remove the event listener.
--
You are receiving this mail because:
You are the assignee for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.webkit.org/pipermail/webkit-unassigned/attachments/20150917/9bed818d/attachment.html>
More information about the webkit-unassigned
mailing list