在应用有frameset或者iframe的页面时,parent是父窗口,top是最顶级父窗口(有的窗口中套了好几层frameset或者iframe),self是当前窗口, opener是用open方法打开当前窗口的那个窗口。
1、window.self
功能:是对当前窗口自身的引用。它和window属性是等价的。
语法:window.self
注:window、self、window.self是等价的
2、window.top
功能:返回顶层窗口,即浏览器窗口。
语法:window.top
注:如果窗口本身就是顶层窗口,top属性返回的是对自身的引用
3、window.parent
功能:返回父窗口
语法:window.parent
注:如果窗口本身就是顶层窗口,parent属性返回的是对自身的引用
在框架网页中,一般父窗口就是顶层窗口,但如果框架中还有框架,父窗口和顶层窗口就不一定相同了。
总结:你应该当将框架视为窗口中的不同区域,框架是浏览器窗口中特定的部分。一个浏览器窗口可以根据你的需要分成任意多的框架,一个单个的框架也可以分成其它多个框架,即所谓的嵌套框架。
注:parent与opener的区别:
parent指父窗口,在frameset中,frame的parent就是frameset窗口。
opener指用window.open方式创建的新窗口对应的原窗口。
parent是相对于框架来说父窗口对象。
opener是针对于用window.open打开的窗口来说的父窗口,前提是window.open打开的才有。
跳转总结:
1、"window.location.href"、"location.href"——是本页面跳转
2、"parent.location.href"——是上一层页面跳转
3、"top.location.href"——是最外层的页面跳转
一、js方式的页面跳转
1、window.location.href方式
<script language="JavaScript" type="text/javascript">
window.location.href="top.jsp";
</script>
注意:如果top.jsp中有iframe标签,则top.jsp页面将会在iframe中被打开。
2、window.loction.replace方式实现页面跳转,注意跟第一种方式的区别
<script language="javascript">
window.location.replace("http://www.dayanmei.com");
</script>
window.location.href和window.loction.replace的区别:
有3个jsp页面(a.jsp, b.jsp, c.jsp),进系统默认的是a.jsp ,当我进入b.jsp的时候, b.jsp里面用window.location.replace("c.jsp");与用window.location.href ="c.jsp";从用户界面来看是没有什么区别的,但是当c.jsp页面有一个"返回"按钮,调用window.history.go(-1); wondow.history.back();方法的时候,一点这个返回按钮就要返回b.jsp页面的话,区别就出来了,当用 window.location.replace("c.jsp");连到c.jsp页面的话,c.jsp页面中的调用 window.history.go(-1);wondow.history.back();方法是不好用的,会返回到a.jsp 。
3、self.location方式实现页面跳转,和下面的top.location有小小区别
<script language="JavaScript">
self.location='top.htm';
</script>
4、top.location
<script language="javascript">
top.location='xx.jsp';
</script>
5、不推荐这种方式跳转
<script language="javascript">
window.history.back(-1);
</script>
6、页面自动刷新:把如下代码加入<head>区域中
<meta http-equiv="refresh" content="20">
其中20指每隔20秒刷新一次页面.
7、<a href="javascript:history.go(-1)">返回上一步</a>
8、<a href="<%=Request.ServerVariables("HTTP_REFERER")%>">返回上一步</a>
9、<a href="javascript:" onClick="window.open('http://hi.baidu.com/630270730','','height=500,width=611,scrollbars=yes,status=yes')">打开新窗口</a>
10、window.history.forward()返回下一页
11、window.history.go(返回第几页,也可以使用访问过的URL)
二、iframe中页面跳转
1、iframe页面跳转:
"window.location.href"、"location.href"是本页面跳转
"parent.location.href"是上一层页面跳转
"top.location.href"是最外层的页面跳转
例:如果A,B,C,D都是jsp,D是C的iframe,C是B的iframe,B是A的iframe,如果D中js这样写
"window.location.href"、"location.href":D页面跳转
"parent.location.href":C页面跳转
"top.location.href":A页面跳转
2.iframe中的target
如果D页面中有form的话, form提交后D页面跳转
<form target="_blank">: form提交后弹出新页面
<form target="_parent">: form提交后C页面跳转
<form target="_top"> : form提交后A页面跳转
三、iframe页面刷新
D 页面中这样写:"parent.location.reload();": C页面刷新
(当然,也可以使用子窗口的 opener 对象来获得父窗口的对象:window.opener.document.location.reload(); )
"top.location.reload();": A页面刷新
注:window.location.href = window.location.href 也可以实现页面刷新,它与reload的区别是:如果在reload之前向服务器提交过数据,那么执行reload会重新执行这个提交操作。 而window.location.href = window.location.href 则不会,因为它是重新进入页面。
举个例子:如果A,B,C,D都是html,D是C的iframe,C是B的iframe,B是A的iframe,如果D中js这样写
1、window.open("Url地址","_blank") = window.open("Url地址");//在新窗口打开
2、location = window.location = location.href = window.location.href =self.location.href = "Url地址";//在D页面实现展现
3、window.open("Url地址","_self");//在D页面实现展现
4、parent.location.href = window.parent.location.href ="Url地址";//在C页面实现展现
5、window.open("Url地址","_parent");//在C页面实现展现
6、top.location.href = window.top.location.href ="Url地址";//在A页面实现展现
7、window.open("Url地址","_top");//在A页面实现展现
8、parent.parent.location = "Url地址";//在B页面实现展现
9、parent.open("Url地址","_parent") = parent.parent.open("Url地址","_self");//在B页面实现展现
如果D页面中有form的话:
1、<form>: form提交后D页面跳转
2、<form target="_blank">: form提交后弹出新页面
3、<form target="_parent">: form提交后C页面跳转
4、<form target="_top"> : form提交后A页面跳转
关于页面刷新,D 页面中这样写:
1、"parent.location.reload();": C页面刷新 (当然,也可以使用子窗口的 opener 对象来获得父窗口的对象:window.opener.document.location.reload(); )
2、"top.location.reload();": A页面刷新
其他应用:
1、js判断窗口或页面是不是在框架中打开的
<script type="text/javascript">
var b = window.parent==window.self;
document.write( "当前窗口是否是底层窗口:"+b );
</script>
2、如果当前窗体不是顶级窗体,就把自己变成最顶层。从而防止别人iframe使用(防止iframe嵌套),常用在登录界面
if (window.top !== window.self) {
window.top.location = window.location;
}
3、子窗口刷新父窗口
<script language=JavaScript>
self.opener.location.reload();
</script>
(或<a href="javascript:opener.location.reload()">刷新</a> )
4、如何刷新另一个框架的页面用
<script language=JavaScript>
parent.另一FrameID.location.reload();
</script>