js父窗口关闭时子窗口随之关闭完美解决方案
更新时间:2014年04月29日 15:21:55 作者:
admin注销的时候,或者main.html关闭的时候,如何让打开的所有新窗口一起关闭,下面有个不错的解决方案,大家可以参考下
最近,遇到一个权限管理的系统。由于权限管理的系统和本来的系统风格不一致,所有新打开一个窗口。问题就来了,admin注销之后,权限管理的窗口没有关闭。其他普通用户登录以后,仍然可以操作权限管理的窗口。
问题简化:admin注销的时候,或者main.html关闭的时候,打开的所有新窗口一起关闭。问题就解决了
直接看代码吧:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body onUnload="closeNews();">
<a href="#" onclick="openNew('http://www.baidu.com','nihao')">打开新窗口</a>
<a href="#" onclick="logOut();">退出登录</a>
</body>
</html>
<script>
//用户记录所有打开的子窗口
var win_Array = new Array();
var win_num = -1;
//每次打开一个新窗口都记录下来
function openNew(uri,param){
win_num = win_num+1;
win_Array[win_num] = window.open(uri);
}
//用户注销的时候,执行关闭方法。body添加onUnload = "closeNews();" 当main窗口关闭时候,所有的子窗口关闭
function closeNews(){
//关闭权限管理
if(win_Array.length > 0){
for(var i = 0;i <= win_Array.length;i++){
var win_one = win_Array[i];
if(win_one != undefined){
win_one.close();
}
}
}
}
function logOut(){
//关闭子窗口
closeNews();
//退出登录
}
</script>
说明一下:
<body onUnload="closeNews();">在body上添加onUnload事件很重要。即:当窗口关闭以后,执行关闭所有子窗口的方法。
测试:在web项目中,ie8,ie10,火狐,chrome,opera都没有问题。
一旦不放倒wen容器中,只是静态的 main.html页面的时候,ie有问题,因为静态的时候,ie的window.open()居然是打开新页面,不是打开新标签。所有关闭窗口的方法不再有效。
时间有限,还没有花精力去细究,还望知道为什么的js技术大神 可以指导一下。再次致谢。
问题简化:admin注销的时候,或者main.html关闭的时候,打开的所有新窗口一起关闭。问题就解决了
直接看代码吧:
复制代码 代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body onUnload="closeNews();">
<a href="#" onclick="openNew('http://www.baidu.com','nihao')">打开新窗口</a>
<a href="#" onclick="logOut();">退出登录</a>
</body>
</html>
<script>
//用户记录所有打开的子窗口
var win_Array = new Array();
var win_num = -1;
//每次打开一个新窗口都记录下来
function openNew(uri,param){
win_num = win_num+1;
win_Array[win_num] = window.open(uri);
}
//用户注销的时候,执行关闭方法。body添加onUnload = "closeNews();" 当main窗口关闭时候,所有的子窗口关闭
function closeNews(){
//关闭权限管理
if(win_Array.length > 0){
for(var i = 0;i <= win_Array.length;i++){
var win_one = win_Array[i];
if(win_one != undefined){
win_one.close();
}
}
}
}
function logOut(){
//关闭子窗口
closeNews();
//退出登录
}
</script>
说明一下:
<body onUnload="closeNews();">在body上添加onUnload事件很重要。即:当窗口关闭以后,执行关闭所有子窗口的方法。
测试:在web项目中,ie8,ie10,火狐,chrome,opera都没有问题。
一旦不放倒wen容器中,只是静态的 main.html页面的时候,ie有问题,因为静态的时候,ie的window.open()居然是打开新页面,不是打开新标签。所有关闭窗口的方法不再有效。
时间有限,还没有花精力去细究,还望知道为什么的js技术大神 可以指导一下。再次致谢。
相关文章
原生js实现复制对象、扩展对象 类似jquery中的extend()方法
jq的extend()方法能很方便的实现扩展对象方法,这里要实现的是:原生js实现复制对象,扩展对象,类似jq中的extend()方法,需要的朋友可以参考下2014-08-08
最新评论