重载后检测窗口是否存在

所以我想这样做

var myWindow = false; $('someelement').click(function(){ var myWindow = window.open('url', 'name', 'width=100,height=200'); }); 

所以用户点击窗口A上的元素,打开一个新窗口(称之为窗口B)…

但是假设窗口A被重新加载…由于这个原因,var myWindow现在设置为false …但是窗口B仍然打开….如何在窗口A之后从窗口A检测到窗口B的存在得到重新加载

我知道你可以这样做:

 var hasWindow = window.open('', 'name'); 

如果它已经打开,它将返回对窗口B的引用。

但是如果窗口B尚未打开,则会触发窗口打开,这是不合需要的

如果窗口B打开而没有在窗口B未打开的情况下触发新窗口打开,如何获得对窗口B的引用? (不借助cookie技巧)

在不存储cookie的情况下保持LITTLE位状态的最佳方法是将一些内容保存到window.name中。 但它只能使用字符串,所以如果你想要的不仅仅是一点数据,你需要将它保存为JSON字符串。

阅读:

 var keptState; if (window.name !== "") { keptState = JSON.parse(window.name); } 

来写:

 state = { "popupOpened" : true, "popupName" : "otherWindowName" }; window.name = JSON.stringify(state); 

在刷新的另一边(甚至导航离开网站并返回),它会保留您想要的变量。 但是,如果你真的想要引用另一个窗口,那么你就可以自己做了。 我想不出有什么方法可以确定它实际存在。 如果有人自己关闭弹出窗口,这将是一个问题。

至少这样,你可以看出你是否已经打开它。 如果你确实需要那个没有弹出窗口的窗口,那么你可以做一个popunder。 当我这样做时,总觉得有点阴暗,但这可能是你要求的最佳方式。

 var myWindow = window.open('', 'otherWindowName'); myWindow.blur(); window.focus();