您的位置:首页 > Web前端 > JavaScript

javascript关闭窗口不弹出提示对话框!

2013-08-24 13:07 471 查看
由于微软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>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: