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

最近,遇到一个权限管理的系统。由于权限管理的系统和本来的系统风格不一致,所有新打开一个窗口。问题就来了,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技术大神 可以指导一下。再次致谢。

时间: 2025-01-02 18:51:38

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

IE关闭时判断及AJAX注销案例学习_javascript技巧

复制代码 代码如下: <script language="javascript"> window.onbeforeunload = function () { var n = window.event.screenX - window.screenLeft; var b = n > document.documentElement.scrollWidth - 20; if (b && window.event.clientY < 0 || win

JS实现关键字搜索时的相关下拉字段效果_javascript技巧

<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=GBK" /> <title>Hello World</title> <link href="style.css" rel="external nofollow" rel=

js下判断 iframe 是否加载完成的完美方法_javascript技巧

采用的方法很类似: 复制代码 代码如下: var iframe = document.createElement("iframe"); iframe.src = "http://www.jb51.net"; if (!/*@cc_on!@*/0) { //if not IE iframe.onload = function(){ alert("Local iframe is now loaded."); }; } else { iframe.on

JS子父窗口互相操作取值赋值的方法介绍_javascript技巧

$("#父窗口元素ID",window.parent.document); 对应javascript版本为window.parent.document.getElementByIdx_x("父窗口元素ID"): 取父窗口的元素方法:$(selector, window.parent.document);那么你取父窗口的父窗口的元素就可以用:$(selector, window.parent.parent.document); 类似的,取其它窗口的方法大同小异$(se

c#MDI窗口问题,子窗口的实例变量怎么在父窗口里改变

问题描述 c#MDI窗口问题,子窗口的实例变量怎么在父窗口里改变 问题是这样,我想写一个MDI窗体,点Creative创建一个画板,点color改变颜色,但不知道如何在Form1里实现改变颜色这个功能 解决方案 你在弹出子窗体的时候实例化了一个子窗体的对象的 , 通过那个对象 来做

update方法-Java 窗口缩放时使窗口内容也相应缩放

问题描述 Java 窗口缩放时使窗口内容也相应缩放 程序需要实现的就是缩放窗口时调用update方法使窗口内容也随之缩放,其他都能执行,所以我代码也没放上来,就是update里面的addEntry()没办法执行,为什么呢?我把entry和color都创建实例变量了啊,我也有试过把addEntry里面的方法放到update里面,然后直接addentry里调用update方法也不行...本人小白,求大神赐教! ![

js窗口关闭提示信息(兼容IE和firefox)_javascript技巧

很多时候,在浏览网页时,我们需要考虑用户不小心时关闭窗口的情况,特别是当用户有很重要的数据还没有保存,我们的程序有必要对用户进行提醒.这个时候我们可以通过是用javascript window.onbeforeunload() 这个方法来阻止用户关闭窗口,见如下这个例子: <script type="text/javascript"> window.onbeforeunload=function(event){ return 'hello'; } </script&g

一种打开子窗口的方法[父页内创建子窗口]

创建|子窗口 <html> <head> <title>Test</title><script>function openSubWin()   {   subWindow=window.open("", "newwin", "height=250, width=250,toolbar=no ,scrollbars="+scroll+",menubar=no");   

C#怎么样把另一个应用程序域的Form窗口作为当前应用程序域中MDI窗口容器的子窗口

问题描述 简单的说,就是当前默认的应用程序域中把一个窗口作为MDI窗口容器,显然,对当前应用程序域的其他窗口,可以通过简单的设置变成该窗口容器的MDI子窗口.但是,我的开发中需要创建一个应用程序域,让新建的应用程序域加载了一个程序集(比如叫A.exe的.Net程序集),其中A.exe是有自己的窗口界面的.我现在想把A.exe的界面作为当前应用程序域窗口容器的一个MDI子窗口,应该怎么做.因为跨越了应用程序域后,对象并不能直接访问.求高人指点. 解决方案 解决方案二:MAF方面,有关于以上问题相关