重载后检测窗口是否存在
所以我想这样做
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();