首页  >  文章  >  web前端  >  js父窗口关闭时子窗口随之关闭完美解决方案_javascript技巧

js父窗口关闭时子窗口随之关闭完美解决方案_javascript技巧

WBOY
WBOY原创
2016-05-16 16:50:391292浏览

最近,遇到一个权限管理的系统。由于权限管理的系统和本来的系统风格不一致,所有新打开一个窗口。问题就来了,admin注销之后,权限管理的窗口没有关闭。其他普通用户登录以后,仍然可以操作权限管理的窗口。

问题简化:admin注销的时候,或者main.html关闭的时候,打开的所有新窗口一起关闭。问题就解决了

直接看代码吧:

复制代码 代码如下:





Insert title here



打开新窗口
退出登录



<script> <BR>//用户记录所有打开的子窗口 <BR>var win_Array = new Array(); <BR>var win_num = -1; <br><br>//每次打开一个新窗口都记录下来 <BR>function openNew(uri,param){ <BR>win_num = win_num+1; <BR>win_Array[win_num] = window.open(uri); <BR>} <br><br>//用户注销的时候,执行关闭方法。body添加onUnload = "closeNews();" 当main窗口关闭时候,所有的子窗口关闭 <BR>function closeNews(){ <BR>//关闭权限管理 <BR>if(win_Array.length > 0){ <BR>for(var i = 0;i <= win_Array.length;i++){ <BR>var win_one = win_Array[i]; <BR>if(win_one != undefined){ <BR>win_one.close(); <BR>} <BR>} <BR>} <BR>} <br><br>function logOut(){ <BR>//关闭子窗口 <BR>closeNews(); <br><br>//退出登录 <BR>} <br><br></script>

说明一下:

在body上添加onUnload事件很重要。即:当窗口关闭以后,执行关闭所有子窗口的方法。

测试:在web项目中,ie8,ie10,火狐,chrome,opera都没有问题。

一旦不放倒wen容器中,只是静态的 main.html页面的时候,ie有问题,因为静态的时候,ie的window.open()居然是打开新页面,不是打开新标签。所有关闭窗口的方法不再有效。

时间有限,还没有花精力去细究,还望知道为什么的js技术大神 可以指导一下。再次致谢。
声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn