背景:点击父页面中按钮,使用window.open()打开对应按钮下的子页面;
问题:同一按钮点击多次,会同时打开多个窗口,影响体验;
期望:同一按钮点击多次,只保留一个窗口,自动获取页面是否已经被打开。
解决方案一:添加定时setInterval();
根据window.open() 有返回值特性,进行定时检测;在打开一个窗口(调用window.open)时,对其结果进行判断,如果状态为关闭,则执行打开页面操作;
测试缺陷:对于已经打开窗口进行判断时,已打开窗口无法保持在最前面;但是可以有效防止页面被多次打开。
var newWin = window.open(url,name,"height=500,width=1000");
var loop = setInterval(function() {
if(newWin &&newWin .closed) {
clearInterval(loop);
$("body",parent.document).unmask();
}, 1000);
解决方案二:使用window.onunload 进行监测
采用window.open父页面/子页面传值进行处理;通过监控子页面关闭事件进行处理(window.onunload())
测试效果可以接受:页面只打开一个,最初页面始终保存在最前面;功能正常。
//父页面:
var openWinStatus ='close';//默认状态为关闭
function openChild(){
if(openWinStatus =='opening'){
return;
}else{
openWinStatus ='opening'
window.open(url,name,othersetting);
//子页面
window.onunload =function(){
try {
//父页面定义 openWinStatus ;修改变量值
window.opener.openWinStatus = 'close';
}catch(e){