失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > Asp.net 5种页面转向方法 转载

Asp.net 5种页面转向方法 转载

时间:2021-12-05 06:09:55

相关推荐

Asp.net 5种页面转向方法 转载

上周随手记下 中Application Session Cookie ViewState Cache Hidden,本来感觉应该没有什么问题的,大家还是指出了遗漏甚至是错误的知识点,在此感谢一下园子里的兄弟:aspnetx 书生 Zfphere,收获不小。作为一种复习和梳理的方法,这一周我们继续进行。本周的话题是:的页面转向方法,这一次你看我数全了么?(有问题还是请拍砖)……

<a>标签

1. <a href=”test.aspx”></a>

2. 这是最常见的一种转向方法;

HyperLink控件

1. 服务器端控件 属性NavigateUrl指定要跳转到的Url地址

2. NavigateUrl是可以在服务器端使用代码修改,这个区别于<a>

3. 由于HyperLink本身没有事件所以要在服务器端其它事件中设置NavigateUrl

4. 代码示例

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

Response.Redirect()方法

1. 过程:发送一个Http响应到客户端,通知客户端跳转到一个新的页面,然后客户端再发送跳转请求到服务器端。

2. 页面跳转之后内部控件保存的所有信息丢失,当A跳转到B,B页面将不能访问A页面提交的数据信息。

3. 使用这个方法使用这个方法跳转后浏览器地址栏的Url信息改变

4. 可以使用Session Cookies Application等对象进行页面间的数据传递

5. 重定向操作发生在客户端,总共涉及到两次与Web服务器的通信:一次是对原始页面的请求,另一次是重定向新页面的请求

Server.Transfer()方法

1. 实现页面跳转的同时将页面的控制权进行移交

2. 页面跳转过程中Request Session等保存的信息不变,跳转之后可以使用上一个页面提交的数据

3. 跳转之后浏览器地址栏的Url不变

4. 这种方法的重定向请求是在服务器端的进行的,浏览器不知道页面已经发生了一次跳转

Server.Execute()方法

1. 该方法允许当前页面执行同一个Web服务器上的另一个页面

2. 页面执行完毕之后重新回到原始页面发出Server.Execute()的位置。

3. 这种方式类似针对页面的一次函数调用 被请求的页面可以使用原始页面的表单数据和查询字符串集合

4. 被调用页面的Page指令的EnableViewStateMac属性设置为False

话题相关:

1. 为了确保HTML输出的合法性 最好使用Response.Redirect方法;因为Server.Execute 或者Server.Transfer方法返回给客户端的页面包含多个<Html><body>标记,不是合法的HTML页面,在非IE浏览器中可能会发生错误。

2. 由于Server.Transfer在服务器端执行重定向,所以避免了不必要的网络通信,从而获得了更好的性能和浏览效果

发表于 -07-09 07:26 坚强2002 阅读(315) 评论(6) 编辑收藏 引用 网摘 所属分类: 知识积累评论 re: 随手记下 5种页面转向方法 HyperLink对比a的最大好处是支持ResolveUrl。a其实也可以runat="server",虽然感觉有点怪,但至少可以在服务器端对它进行一般控件都能进行的赋值和数据绑定操作,然而ResolveUrl则是它布局别的,如果要用"~/Default.aspx"这样的路径则最好用HyperLink。评论于 -07-09 08:07re: 随手记下 5种页面转向方法 Server.Execute和Server.Transfer视乎你怎么用,通常调用之前都应该Response.Clear()清除之前的输出,调用之后Response.Flush()和Response.End()结束处理。评论于 -07-09 08:08re: 随手记下 5种页面转向方法 还有一个小方法

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

Response.write("<script language=javascript>history.back();</script>)

刚刚学来的

如果觉得《Asp.net 5种页面转向方法 转载》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。