关于C#.Net网页跳转的7种方法

一、目前在ASP.NET中页面传值共有这么几种方式:

1.Response.Redirect("http://www.hao123.com",false); 
目标页面和原页面可以在2个服务器上,可输入网址或相对路径。后面的bool值为是否停止执行当前页。
跳转向新的页面,原窗口被代替。
浏览器中的URL为新路径。
Response.Redirect方法导致浏览器链接到一个指定的URL。当Response.Redirect()方法被调用时,它会创建一个应答,应答头中指出了状态代码302(表示目标已经改变)以及新的目标URL。浏览器从服务器收到该应答,利用应答头中的信息发出一个对新URL的请求。这就是说,使用Response.Redirect方法时重定向操作发生在客户端,总共涉及到两次与服务器的通信(两个来回):第一次是对原始页面的请求,得到一个302应答,第二次是请求302应答中声明的新页面,得到重定向之后的页面。
 
2.Server.Transfer("Default2.aspx?name=zhangsan",true);
目标页面和原页面可以在同一个服务器上。
跳转向新的页面,原窗口被代替。
浏览器中的URL为原路径不变。
默认情况下,Server.Transfer方法不会把表单数据或查询字符串从一个页面传递到另一个页面,但只要把该方法的第二个参数设置成True,就可以保留第一个页面的表单数据和查询字符串。同时,使用Server.Transfer时应注意一点:目标页面将使用原始页面创建的应答流,这导致ASP.NET的机器验证检查(Machine Authentication Check,MAC)认为新页面的ViewState已被篡改。因此,如果要保留原始页面的表单数据和查询字符串集合,必须把目标页面Page指令的EnableViewStateMac属性设置成False。
 
3.Server.Execute("Default5.aspx?address=beijing);
目标页面和原页面可以在同一个服务器上。
跳转向新的页面,再跳转会原页面。
浏览器中的URL为原路径不变。
当指定的ASPX页面执行完毕,控制流程重新返回原页面发出Server.Execute调用的位置。
这种页面导航方式类似于针对ASPX页面的一次函数调用,被调用的页面能够访问发出调用页面的表单数据和查询字符串集合,所以要把被调用页面Page指令的EnableViewStateMac属性设置成False。
 
4.Response.Write("<script language='javascript'>window.open('aaa.aspx');</script>");
目标页面和原页面可以在2个服务器上,可输入网址或相对路径。
原窗口保留,另外新增一个新页面。
 
5.Response.Write("<script language='javascript'>window.location='Default2.aspx'</script>");
打开新的页面,原窗口被代替。
 
6.Response.Write("<script>window.showModalDialog('Default2.aspx')</script>");
 
7.Response.Write("<script>window.showModelessDialog('Default2.aspx')</script>");
(一)、showModalDialog和showModelessDialog有什么不同?
showModalDialog:被打开后就会始终保持输入焦点。除非对话框被关闭,否则用户无法切换到主窗口。类似alert的运行效果。
showModelessDialog:被打开后,用户可以随机切换输入焦点。对主窗口没有任何影响(最多是被挡住一下而以。:P)
(二)、怎样才让在showModalDialog和showModelessDialog的超连接不弹出新窗口?
在被打开的网页里加上<base target="_self">就可以了。这句话一般是放在<html>和<body>之间的。
同时新打开两个页面
<input type="button" value="button" οnclick="window.open('1.aspx');window.open('2.aspx');" />

二、如果在两个页面间需要大量的参数要传传递,如数据查询等页面时,用1 - 6的方法传值及其不便,而第 7 种方法确有一独特的优势!但使用该方法时需要一定的设置,现简单介绍一下该方法的使用方式:
 
以查询数据页面为例:
在查询页面中设置如下公有属性(QueryPage.aspx):
 
public class QueryPage : System.Web.UI.Page
{
        protected System.Web.UI.WebControls.TextBox txtStaDate;
        protected System.Web.UI.WebControls.TextBox txtEndDate;
        ...
        /// <summary>
        /// 开始时间
        /// </summary>
        public string StaDate
        {
                get{ return this.txtStaDate.Text;}
                set{this.txtStaDate.Text = value;}
        }
        /// <summary>
        /// 结束时间
        /// </summary>
        public string EndDate
        {
                get{ return this.txtEndDate.Text;}
                set{this.txtEndDate.Text = value;}
        }
        ...
        private void btnEnter_Click(object sender, System.EventArgs e)
        {
                Server.Transfer("ResultPage.aspx");
        }
}
 
在显示查询结果页面(ResultPage.aspx): 
public class ResultPage : System.Web.UI.Page
{
        private void Page_Load(object sender, System.EventArgs e)
        {
                //转换一下即可获得前一页面中输入的数据
                QueryPage queryPage = ( QueryPage )Context.Handler;
                Response.Write( "StaDate:" );
                Response.Write( queryPage.StaDate );
                Response.Write( "<br/>EndDate:" );
                Response.Write( queryPage.EndDate );
        }
}
 
三、如果有许多查询页面共用一个结果页面的设置方法:
 
    在这种方式中关键在于“ QueryPage queryPage = ( QueryPage )Context.Handler; ”的转换,只有转换不依赖于特定的页面时即可实现。
    如果让所有的查询页面都继承一个接口,在该接口中定义一个方法,该方法的唯一作用就是让结果页面获得构建结果时所需的参数,就可实现多页面共享一个结果页面操作!
 
1、先定义一个类,用该类放置所有查询参数: 
/// <summary>
/// 结果页面中要用到的值
/// </summary>
public class QueryParams
{
        private string staDate;
         private string endDate;
        /// <summary>
        /// 开始时间
        /// </summary>
        public string StaDate
        {
                get{ return this.staDate;}
                set{this.staDate = value;}
        }
        /// <summary>
        /// 结束时间
        /// </summary>
        public string EndDate
        {
                get{ return this.endDate;}
                set{this.endDate = value;}
        }
}
 
2、接口定义: 
/// <summary>
/// 定义查询接口。
/// </summary>
public interface IQueryParams
{
        /// <summary>
        /// 参数
        /// </summary>
        QueryParams Parameters{get;}
}
 
3、查询页面继承IQueryParams接口(QueryPage.aspx): 
/// <summary>
///查询页面,继承接口
/// </summary>
public class QueryPage : System.Web.UI.Page, IQueryParams
{
        protected System.Web.UI.WebControls.TextBox txtStaDate;
        protected System.Web.UI.WebControls.TextBox txtEndDate;
        private QueryParams queryParams;
        ...
        /// <summary>
        /// 结果页面用到的参数
        /// </summary>
        public QueryParams Parameters
        {
                get
                { return queryParams; }
        }
        ...
        private void btnEnter_Click(object sender, System.EventArgs e)
        {
                //赋值
                queryParams = new QueryParams();
                queryParams.StaDate = this.txtStaDate.Text;
                queryParams.EndDate = this.txtEndDate.Text
                Server.Transfer("ResultPage.aspx");
        }
}
 
4、别外的页面也如此设置
 
5、接收页面(ResultPage.aspx):
public class ResultPage : System.Web.UI.Page
{
        private void Page_Load(object sender, System.EventArgs e)
        {
                QueryParams queryParams = new QueryParams();
                IQueryParams queryInterface;
                //实现该接口的页面
                if( Context.Handler is IQueryParams)
                {
                        queryInterface = ( IQueryParams )Context.Handler;
                        queryParams = queryInterface.Parameters;
                }
                Response.Write( "StaDate:" );
                Response.Write( queryParams.StaDate );
                Response.Write( "<br/>EndDate:" );
                Response.Write( queryParams.EndDate );
        }
}

原文:https://www.cnblogs.com/yangwujun/p/5142325.html文章来源地址https://uudwc.com/A/8d16v

原文地址:https://blog.csdn.net/tony0225/article/details/133122547

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

上一篇 2023年09月24日 19:04
vue部分/所有内容全屏切换展示
下一篇 2023年09月24日 19:05