ASP.NET 中 “返回上一页”的实现方法小结

方法一:

<input type="button onclick="javascript:window.history.go(-1);"value="返回上一页">

方法二

在button的onClick事件响应函数中写如下代码:

This.ClientScript.RegisterClientScriptBlock(this.GetType(), "e", "<script language=javascript>history.go(-2);</script>", true);

剖析

假设当前页面为A,上一页为B,则当A中的button被按下后,A页面会立即被回发到服务器进行处理,服务器端向A页面中添加了我们写的那个script块。

我们感到按钮被按下之后,页面刷新了一下,然后我们看到的已不是页面A了,而是全新的A+页面,A+比A多了一个script块。

浏览器解析A+页面过程中遇到了script块,就执行javascript语句,执行到history.go(-2)时就连着退后两步。先从A+页面退到A页面,再从A页面退到B页面。

于是就完成了整个回退过程。

 

方法一中之所以只回退一步,是因为它的button没有runat="server"属性,所以按钮被按下之后并不回发到服务器,于是只回退一步,就从A回到B了。

方法三

在page_load中加入

if(!IsPostBack)

        ViewState["retu"]=Request.UrlReferrer.ToString();  

 

而在返回按钮事件中

if(ViewState["retu"]!=null){

       Response.Redirect(ViewState["retu"].ToString());    

}

else

{

      Response.write("对不起,当前是最前页码“);

}

注意:

以下这段来自:http://stswordman.cnblogs.com/archive/2006/06/12/423910.html

在使用Request.UrlReferrer时:

1. 如果上一页面使用document.location方法导航到当前页面,Request.UrlReferrer返回空值

2. 如果有A,B两个页面,在浏览器中直接请求A页面,在A页面的中Page_Load事件中导航到B页面,则Request.UrlReferrer返回空。因为在Page_load事件中页面还未初始化,所以无法记录当前页的信息,导航到B页面也就无法获得上一页面的信息。

3. 点击刷新按钮不会改变Request.UrlReferrer

方法四

<a href=<%=request.servervariable.GetValues("http_Referre")%>上一页</a>

总结

方法1、2是通过javascript通知浏览器回到上一页,浏览器将调出本地缓存中的上一页数据,所以回到上一页后,表单数据还被保留着。

而方法3、4则是通过在本页记录下上一页的url,然后在你点击“上一页”按钮时重新向服务器发出http请求,再次请求这个url,所以你得到的“上一页”将是全新的页面,以前填写的表单数据都没有了。

参考 <http://www.cnblogs.com/majunyue/archive/2009/02/06/1385355.html>

posted @ 2011-08-30 16:08  一方一净土  阅读(376)  评论(0编辑  收藏  举报