• ASP.NET页面跳转


    总结一下跳转方式:

    <a>标签

    <a href=”home.aspx”></a>

    HyperLink控件

    Asp.net 服务器端控件 属性NavigateUrl指定要跳转到的Url地址,NavigateUrl是可以在服务器端使用代码修改,这个区别于<a>,由于HyperLink本身没有事件所以要在服务器端其它事件中设置NavigateUrl.

    <Asp:HyperLink id=”hyperlink” runat=”server” NavigatoeUrl=”test.aspx”>ok</Asp:HyperLink>

    Response.Redirect()

    1.发送一个Http响应到客户端
    2.通知客户端跳转到一个新的页面
    3.然后客户端再发送跳转请求到服务器端
    4.页面跳转之后内部控件保存的所有信息丢失
    5.当A跳转到B,B页面将不能访问A页面提交的数据信息
    使用这个方法使用这个方法跳转后浏览器地址栏的Url信息改变,可以使用Session Cookies Application等对象进行页面间的数据传递,重定向操作发生在客户端,总共涉及到两次与Web服务器的通信:一次是对原始页面的请求,另一次是重定向新页面的请求.

    JavaScript

    string newuri = "<script language=javascript>history.go(-2);</script>";
    Response.Write(newuri );


    Server.Transfer()

    实现页面跳转的同时将页面的控制权进行移交,页面跳转过程中Request Session等保存的信息不变,跳转之后可以使用上一个页面提交的数据,跳转之后浏览器地址栏的Url不变.
    这种方法的重定向请求是在服务器端的进行的,浏览器不知道页面已经发生了一次跳转

    Server.Execute()

    该方法允许当前页面执行同一个Web服务器上的另一个页面,页面执行完毕之后重新回到原始页面发出Server.Execute()的位置。
    这种方式类似针对页面的一次函数调用 被请求的页面可以使用原始页面的表单数据和查询字符串集合,被调用页面的Page指令的EnableViewStateMac属性设置为False.

    为确保HTML输出的合法性 最好使用Response.Redirect;

    因为Server.Execute 或者Server.Transfer方法返回给客户端的页面包含多个<Html><body>标记,不是合法的HTML页面,在非IE浏览器中可能会发生错误。
    Server.Transfer在服务器端执行重定向,避免了不必要的网络通信,具有更好的性能和浏览效果。

    转载请保留原地址. http://www.cnblogs.com/lsqandzy
  • 相关阅读:
    ngnix-内网能用,外网不能用
    python学习
    mysql数据库导出xls-自定义
    Oralce-资源配置PROFILE
    oracle-用户管理与权限分配
    Oracle-创建索引分区
    Oracle-表分区
    Oracle--索引视图序列等对象
    Oracle-数据表对象
    Oracle-管理表空间和数据文件
  • 原文地址:https://www.cnblogs.com/lsqandzy/p/4248648.html
Copyright © 2020-2023  润新知