如何退出一个框架页面的几种方法
2015-04-03 10:34
267 查看
在做项目的时候我们经常会用到一些Iframe框架结构的情况,下面我们就来说说如何退出框架页的操作,如:
先普及一点相关的知识点:
window 对象某些属性的相关信息。
属性 方法 描述
opener open opener 属性仅在使用 window.open 方法打开的页面中可用。
parent, top 无 parent 和 top 属性对 frame 或 iframe 内打开的窗口可用。这两个属性分别返回立即父窗口和最上层的祖先窗口。
parent, top open parent 和 top 属性对于通过 open 方法打开或以对话框打开并返回到当前窗口的窗口可用。
length 无 不管窗口是怎么打开的,length 属性总是返回窗口中的框架数目。
dialogArguments, dialogHeight, dialogLeft, dialogTop, dialogWidth, returnValue showModalDialog 和 showModelessDialog
parent 获取对象层次中的父窗口。
top 获取最顶层的祖先窗口。
window属性:
opener 设置或获取创建当前窗口的窗口的引用。
self 获取对当前窗口或框架的引用。
windown方法:
close 关闭当前浏览器窗口或 HTML 应用程序(HTA)。
open 打开新窗口并装入给定 URL 的文档。
小结一下:
两句任意选一句都可完成表面上类似同样的效果。
但是实际效果上的差别:
Response.Write("<script language=javascript>parent.location.href='Login.aspx'</script>");
这里将parent换成top也可以,没仔细研究为什么。自己使用。我在我的框架里top,left.right(三个框架的right使用无任何问题)
这个是直接转向到新页面,但是地址栏上的后退仍然是可以后退的,虽然点后退会在次返回,可是如我上面的写法,在page_load里,会再次提示“登陆超时,请重新登陆”确定后再返回。这样的效果,我不是很满意,所以得出了下面的使用方法。
Response.Write("<script language=javascript>window.open('Index.aspx');opener=null;top.close();</script>");
这个的功能是什么实际效果呢?很简单,打开新窗口后,接下来,将原来的框架窗口关闭,注意是新窗口,那么当然后退按钮就变成灰色的了。客户端自然无法后退了。这个效果我比较喜欢。很符合我的原意(比如:不用考虑重复提交之类的问题了)。
另外我加上opener=null这句,是根据我的理解加上去的,好象去掉也照样可以实现同样的效果。这里如果将top换parent也同样可以使用。但是如果换window.close()那提示框又回来了。以上都是在IE6.0以上版本实现的效果,别的浏览器没试验过。
小注:在查阅资料的时候,有的是这样说,在需要关闭的窗口<body>里加上onblur="self.close()",然后在用window.close()方法关闭当前窗口也不会出现提示,但是试了一下,好像没看到效果;
另外还有这样,如果是用open()方法打开的子窗口里,直接用windown.close()或top.close()都可以直接关闭窗口,经测试,好象这样的情况下,在body加上onblur="self.close()"后,的确是可以的,但是不加的没测试。做个简单的记录。
<frameset rows="98,*,8" frameborder="no" border="0" framespacing="0"> <frame src="Top.aspx" name="topFrame" scrolling="No" noresize="noresize" id="topFrame" /> <frame src="Center.aspx" name="mainFrame" id="mainFrame" /> <frame src="Bottom.aspx" name="bottomFrame" scrolling="No" noresize="noresize" id="bottomFrame" /> </frameset> <noframes> <body> </body> </noframes>
先普及一点相关的知识点:
window 对象某些属性的相关信息。
属性 方法 描述
opener open opener 属性仅在使用 window.open 方法打开的页面中可用。
parent, top 无 parent 和 top 属性对 frame 或 iframe 内打开的窗口可用。这两个属性分别返回立即父窗口和最上层的祖先窗口。
parent, top open parent 和 top 属性对于通过 open 方法打开或以对话框打开并返回到当前窗口的窗口可用。
length 无 不管窗口是怎么打开的,length 属性总是返回窗口中的框架数目。
dialogArguments, dialogHeight, dialogLeft, dialogTop, dialogWidth, returnValue showModalDialog 和 showModelessDialog
parent 获取对象层次中的父窗口。
top 获取最顶层的祖先窗口。
1、直接从框架页中退出,并转向到新的窗口 if (Session["USERNAME"] == null) { Response.Write("<script language=javascript>alert('登陆超时,请重新登陆!!')</script>"); Response.Write("<script language=javascript>top.location.href='Login.aspx'</script>"); } 2、如果需要在框架页中关闭当前窗口并打开新窗口 1)先提示关闭当前窗口,并且在确定关闭当前窗口后,打开新窗口. if (Session["USERNAME"] == null) { Response.Write("<script language=javascript>alert('登陆超时,请重新登陆!!')</script>"); Response.Write("<script>window.parent.close(); window.open('Login.aspx');</script>"); } 类似的效果: if (Session["USERNAME"] == null) { Response.Write("<script language=javascript>alert('登陆超时,请重新登陆!!')</script>"); Response.Write("<script>window.opener=null;top.window.close();</script>"); } 3、在框架中关闭当前窗口,不提示。并且打开新窗口 if (Session["USERNAME"] == null) { Response.Write("<script language=javascript>alert('登陆超时,请重新登陆!!')</script>"); Response.Write("<script>window.open('Login.aspx');top.close();</script>"); } if (Session["USERNAME"] == null) { Response.Write("<script language=javascript>alert('登陆超时,请重新登陆!!')</script>"); Response.Write("<script language=javascript>parent.location.href='Login.aspx'</script>"); Response.Write("<script language=javascript>window.open('Login.aspx');opener=null;top.close();</script>"); }
window属性:
opener 设置或获取创建当前窗口的窗口的引用。
self 获取对当前窗口或框架的引用。
windown方法:
close 关闭当前浏览器窗口或 HTML 应用程序(HTA)。
open 打开新窗口并装入给定 URL 的文档。
小结一下:
两句任意选一句都可完成表面上类似同样的效果。
但是实际效果上的差别:
Response.Write("<script language=javascript>parent.location.href='Login.aspx'</script>");
这里将parent换成top也可以,没仔细研究为什么。自己使用。我在我的框架里top,left.right(三个框架的right使用无任何问题)
这个是直接转向到新页面,但是地址栏上的后退仍然是可以后退的,虽然点后退会在次返回,可是如我上面的写法,在page_load里,会再次提示“登陆超时,请重新登陆”确定后再返回。这样的效果,我不是很满意,所以得出了下面的使用方法。
Response.Write("<script language=javascript>window.open('Index.aspx');opener=null;top.close();</script>");
这个的功能是什么实际效果呢?很简单,打开新窗口后,接下来,将原来的框架窗口关闭,注意是新窗口,那么当然后退按钮就变成灰色的了。客户端自然无法后退了。这个效果我比较喜欢。很符合我的原意(比如:不用考虑重复提交之类的问题了)。
另外我加上opener=null这句,是根据我的理解加上去的,好象去掉也照样可以实现同样的效果。这里如果将top换parent也同样可以使用。但是如果换window.close()那提示框又回来了。以上都是在IE6.0以上版本实现的效果,别的浏览器没试验过。
小注:在查阅资料的时候,有的是这样说,在需要关闭的窗口<body>里加上onblur="self.close()",然后在用window.close()方法关闭当前窗口也不会出现提示,但是试了一下,好像没看到效果;
另外还有这样,如果是用open()方法打开的子窗口里,直接用windown.close()或top.close()都可以直接关闭窗口,经测试,好象这样的情况下,在body加上onblur="self.close()"后,的确是可以的,但是不加的没测试。做个简单的记录。
相关文章推荐
- 页面中包含同一个asp.net控件多次,如何产生不同的javascript方法名
- 前端框架对页面的损害+如何判断一个dom是否存在某个属性
- jsp 一个具有两个frame框架的页面在跳转到新页面时,如何使新页面覆盖当前窗口,不跳转到新的页面
- java web开发中,jsp使用了frameset框架,如何实现整个页面跳转,并且同一个表单中可以提交两个action
- 点击页面上的一个按钮时,如何触发controller中的方法
- jsp页面传递参数的几种方法总结以及一个在线聊天案例
- 如何在退出一个页面时自动清空session变量
- 16、2015.08.03第十七节课 C#1(.net和C#的关系、VS与.net的对应关系、VS2012常用的几种应用程序、C#定义一个类的方法、类页面内容的解释、定义Person的类、调用Person类的方法、命名规范、数值类型)
- 微信小程序,如何在返回前一个页面时,执行前一个页面的方法
- 一个list中包含不同的type时如何遍历?页面如何接收?Jquery调用后台方法?
- 如何构建一个类似于安卓QQ的页面框架(低耦合)
- 原生如何检测变量是否是一个数组的几种方法
- 在vc中调试,如何使一个for循环执行100次,而不退出for循环(调试方法)
- 如何在页面上调用同一个方法
- 软件测试面试 (二)如何测试网页的登录页面 如何测试一个杯子 关于测试方法的
- 如何开发一个java开源框架-----Jvn框架之实现文件的上传以及方法封装(第六讲)八哥实力讲解
- 在框架中,如何实现退出全部界面方法
- 教你如何退出框架集页面返回到首页,用了很有效哦
- 如何让一个div居于页面正中间【实现方法】
- java servlet 几种页面跳转的方法,需要的朋友可以参考一下 在访问网页的过程中,页面自动刷新、跳转和重定向是经常用到的,这里就说说在Java中是如何实现这些功能的! 一、页面自动刷新