js父窗口关闭时,子窗口随之关闭

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

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

直接看代码吧:

[html]

  1. <!DOCTYPE html PUBLIC “-//W3C//DTD HTML 4.01 Transitional//EN” “http://www.w3.org/TR/html4/loose.dtd”>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv=“Content-Type” content=“text/html; charset=UTF-8”>  
  5. <title>Insert title here</title>  
  6. </head>  
  7. <body onUnload=“closeNews();”>  
  8.   
  9. <a href=“#” onclick=“openNew(‘http://www.baidu.com’,’nihao’)”>打开新窗口</a>  
  10. <a href=“#” onclick=“logOut();”>退出登录</a>  
  11. </body>  
  12. </html>  
  13.   
  14. <script>  
  15. //用户记录所有打开的子窗口  
  16. var win_Array = new Array();  
  17. var win_num = -1;  
  18.   
  19. //每次打开一个新窗口都记录下来  
  20. function openNew(uri,param){  
  21.     win_num = win_num+1;  
  22.     win_Array[win_num] = window.open(uri);  
  23. }  
  24.   
  25. //用户注销的时候,执行关闭方法。body添加onUnload = “closeNews();”  当main窗口关闭时候,所有的子窗口关闭  
  26. function closeNews(){  
  27.     //关闭权限管理  
  28.     if(win_Array.length > 0){  
  29.         for(var i = 0;i <= win_Array.length;i++){  
  30.             var win_one = win_Array[i];  
  31.             if(win_one != undefined){  
  32.                 win_one.close();  
  33.             }  
  34.         }  
  35.     }     
  36. }  
  37.   
  38. function logOut(){  
  39.     //退出登录  
  40.     //关闭子窗口  
  41.     closeNews();  
  42. }  
  43.   
  44. </script>  


说明一下:

<body onUnload=”closeNews();”>在body上添加onUnload事件很重要。即:当窗口关闭以后,执行关闭所有子窗口的方法。

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

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

时间有限,还没有花精力去细究,还望知道为什么的js技术大神 可以指导一下。再次致谢。

标签