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

由于微软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>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值