由于微软IE的安全机制,导致在窗口使用window.open("index.html")弹出新窗口的时候,
使用window.close()关闭窗口本身时会出现提示框:
这样弹出的对话框会打断用户的浏览,为了取消这种安全机制,我们可以在
使用window.close();之前,加上window.opener = null;
这样就可以直接产生没有工具条和地址栏的页面,类似与CS的界面效果,
但这究竟是为什么,让我们首先来看下window.opener到底是什么:
window.opener其实返回的是创建当前窗口的那个窗口的引用
比如:
点击了a.html上的一个链接而打开了b.html,或者
通过a.html的form向b.html提交了数据,转向了b.html
那么在b.html的window.opener返回的就是a.html的引用,这时候,如果我们想在b.html中
弹出一个c.html,然后关闭b.html自身,那么此时b.html中的window.opener的值非空,在
微软的IE中,认为window.opener非空的窗口,关闭自身是不安全的,要给用户
弹出关闭确认对话框。
所以这里b.html要关闭自身,必须使window.opener=null;
如果是通过子窗体关闭父窗体时呢
子窗体(弹出窗体):
代码如下:<script>window.opener.top.opener=null;window.opener.top.close()</script>