window.location.href详解

在写web程序的时候,我们经常遇到跳转页面的问题,我们经常使用Response.Redirect做页面跳转,如果客户要在跳转的时候使用提示,这个就不灵光了,如:

Response.Write("<script>alert('恭喜您,注册成功!');</script>"); 

Response.Redirect("main.html");  

 

这时候我们的提示内容没有出来就跳转了,和Response.Redirect("main.html");没有任何区别。

这时我们采用下面代码试验一下:

ASP.NET框架页跳转的另一实现

Response.Write("<script language=javascript>alert('恭喜您,注册成功!')< /script>"); 

Response.Write("<script language=javascript>window.location.href='main.html'</script>");

 

这个即实现了我们的要求,在提示后,跳转页面。

最重要的是window.location.href语句可以实现一个框架的页面在执行服务器端代码后刷新另一个框架的页面(Response.Redirect无法达到,至少我没有发现)

如:index.htm页面中有二个框架,分别为frameLeftframeRight,在frameRight页面中执行服务器端代码后刷新frameLeft中的页面。

先前最常见的是注册之后,自动刷新登陆框,让登陆框换成已登陆页面,只要在注册成功的代码之后加上一段,即可以实现刷新另个框架的页面。代码如下:

Response.Write("<script language=javascript>alert('恭喜您,注册成功!')< /script>"); 

Response.Write("<scriptlanguage=javascript>window.parent.frameLeft.location.href='main.html'</script>");  

 

这样就搞定了页面跳转中断的问题。

=====================================================================================

"window.location.href""location.href"是本页面跳转

"parent.location.href"是上一层页面跳转

"top.location.href"是最外层的页面跳转

举例说明:

如果A,B,C,D都是jspDCiframeCBiframeBAiframe,如果Djs这样写

"window.location.href""location.href"D页面跳转

"parent.location.href"C页面跳转

"top.location.href"A页面跳转

如果D页面中有form的话,

<form>: form提交后D页面跳转

<form target="_blank">: form提交后弹出新页面

<form target="_parent">: form提交后C页面跳转

<form target="_top"> : form提交后A页面跳转

关于页面刷新,D页面中这样写:

"parent.location.reload();": C页面刷新(当然,也可以使用子窗口的 opener对象来获得父窗口的对象:window.opener.document.location.reload();

"top.location.reload();": A页面刷新

posted @ 2013-12-03 16:35  培杰  阅读(3543)  评论(0编辑  收藏  举报