Is there anything that prevents me from adding a event listener to the window that results from a window.open()
call?
I am trying to set a handler function to be triggered on a visibility change event on the new document, but this handler function is not being called.
Is there anything that prevents me from adding a event listener to the window that results from a window.open()
call?
I am trying to set a handler function to be triggered on a visibility change event on the new document, but this handler function is not being called.
Share Improve this question edited Nov 14, 2021 at 15:04 Brian Tompsett - 汤莱恩 5,89372 gold badges61 silver badges133 bronze badges asked May 4, 2015 at 21:38 IzabelaIzabela 3431 gold badge4 silver badges15 bronze badges 1-
Is the document you are opening with
window.open()
the same origin (e.g. same domain, port and protocol) as the one you are opening it from? If not, then the browser restricts what you can do with a cross origin document, including the installation of event handlers. – jfriend00 Commented May 4, 2015 at 22:25
1 Answer
Reset to default 7There's nothing that prevents you from doing that (as long as the window you are opening is in the same domain as the parent/opener window; Just imagine what malicious people could do if that weren't the case).
Once you have the window
object of that new window, then you can do whatever you want to it. window.open()
returns the window
object of the new window:
// * All of this code is happening inside of the parent window,
// * but you can also 'inject' scripts into the new window if you wish.
// window.open() returns the new window's window object
var newWin = window.open('http://stackoverflow.');
// Run all of your code onload, so you can manipulate the
// new window's DOM. Else, you're just manipulating an empty doc.
newWin.onload = function () {
// `this`, in this context, makes reference to the new window object
// You can use DOM methods, on the new document, with it.
var myElem = this.document.getElementById('custom-header');
console.log("Window object: ", this);
console.log("Window's location: ", this.location.href);
console.log("Id of element in new window: ", myElem.id);
// Attach a click event to the new document's body
this.document.body.onclick = function () {
// `this`, inside of a listener, is the element itself
// but this console.log will log inside of the parent window
console.log(this);
this.style.transition = 'all 1s';
this.style.opacity = 0;
};
this.document.body.addEventListener('click', function () {
// Now, let's log inside of the new window.
// Since in here, this === this.document.body,
// then you'll have to use the newWin var we set before.
// newWin is the window object.
newWin.console.log('Logging in new window!');
});
};