ASP.NET中PostBack和ViewState

简介:

ASP.NET中PostBack和ViewState

关于PostBack,我曾经也写过一篇博客《深入理解doPostBack》。在这篇文章里有对PostBack进行了一些研究,现在看来研究的还是不够深入。不过从原理上来说,ASP.NET WebForm中的一般WEB控件(为什么是一般呢?因为如Button等少数控件不是调用doPostBack方法的)在向服务器回发请求时,调用的就是doPostBack方法,通过表单提交的方式来向服务器提交请求。而WebForm所提供的WEB事件模型也是以doPostBack这个方法为基础的,往服务器传送的两个隐含变量(EVENTTARGET,EVENTARGUMENT)就是PostBack事件分发的根据。EVENTTARGET保存着向服务器发出PostBack请求的控件ID,ASP.NET根据这个ID就可以找到它所对象的服务器端控件的实例。EVENTARGUMENT保存的是当前PostBack的一些参数。除此之外,PostBack还需要什么条件呢?

在前段时间关于WebForm和MVC的讨论中,有人提到禁用了ViewState,也就无法使用了PostBack。这也给我提了一个醒,确实ViewState与PostBack有非常紧密的关系,在大多数情况下,如果控件的状态是动态维护的。比如说DropDownList的Items是通过下面的代码添加的:

protectedvoidPage_Load(objectsender,EventArgse)  {  if(!this.IsPostBack)  {  DropDownList1.Items.Add(newListItem("1","Value1"));  DropDownList1.Items.Add(newListItem("2","Value2"));  }  } 

而不是在HTML页面上静态添加(或是在OnInit事件之前添加,不能加IsPostBack的判断),这时,如果禁用ViewState,那么DropDownList的SelectedIndexChanged事件将不会被正常触发,并且DropDownList的Item项将会被清空。所以从这个角度来说,如果要使用PostBack,那么ViewState势必不能被禁用。

除此之外,PostBack还有一些不足:

1)页面在PostBack后,刷新页面时会出现非常不好的用户体验。

2)搜索引擎的不友好。

3)在编写服务器端代码时要特别的小心,特别是对IsPostBack的判断。

尽管PostBack在WebForm的事件机制占有举足轻重的地位,它出现极大的方便了我们以事件驱动方式来开发WEB应用。从短期的入门应用中确实有它重要的意义。但从现实出发,还是必须得根据不同的应用场合有先择性的使用。在网站前台型应用中,应该消灭一切可以消灭的PostBack。因为做为前台,它的作用就是展示还有查询。而如果对查询,分页等操作使用PostBack的话,一方面搜索引擎的不友好,另一方面给大多数用户带来非常不好的用户体验,增加了整个页面的请求时间。同时,它们所传的参数又非常有限,这情况下就需要使用链接的方式来传参。

对于应用型的后台开发,由于在提交数据时可能会有比较多的表单数据。这时,这时结合DetailView或FormView,使用PostBack来提交数据又可以给我们带来非常大的方便,这种情况下我们不禁用ViewState也没有关系,ViewState并不会很大,而至于刷新的问题,我们可以使用UpdatePanel来帮助解决。但是如果对于浏览数据仍然是要特别注意,特别是有GridView的页面进行PostBack数据查询,分页时,尽量都能改成链接的方式来实现。

总体来说,PostBack的使用还是要特别注意,能少用就少用,但有时用它确实也会给我们带来非常大的方便。对于应用型的后台开发,如果使用EXT的话,那么就是可以完全摒弃WebForm,或MVC了。因为它有自己一整套完整的开发流程,从目前来看,确实是一种全新的体验。

连续两篇讨论的PostBack和ViewState,可能结论都是偏向消极的。它们的存在有其重要意义的同时,难免会带来一些负面影响,但这种影响的代价在很多情况下过大而导致大多数人的反唇相讥。在软件工程中,衡量软件的标准不是越快越好,而是在用户接受的合理的时间范畴内,得到正确的结果,并且它所花费的代价(包括开发,维护,部署等成本)是最少的。我相信只要使用得当,它们还是可以充分发挥它们的作用的。

从极端的来说,去掉PostBack和ViewState后,WebForm仍然还是WebForm。它只是少了两样两把利弊同样明显的双刃剑,它余下的事件机制,组件化开发,页面模型仍然是我们进行WebForm开发最有力的武器。



本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/archive/2010/12/27/1918240.html,如需转载请自行联系原作者

目录
相关文章
|
Web App开发
一起谈.NET技术,Application、Session、Cookie、ViewState、Cache、Hidden的区别
方法 信息量大小 作用域和保存时间 应用范围 保存位置 Application 任意大小 整个应用程序的生命期 整个应用程序/所有用户 服务器端 Cache 任意大小 可以根据需要设定 整个应用程序/所有用户 服务器端 S...
1483 0
|
.NET 开发框架 架构师
|
Web App开发 存储 缓存
[Asp.Net]状态管理(Session、Application、Cache、Cookie 、Viewstate、隐藏域 、查询字符串)
原文:[Asp.Net]状态管理(Session、Application、Cache、Cookie 、Viewstate、隐藏域 、查询字符串) Session:  1. 客户在服务器上第一次打开Asp.Net页面时,会话就开始了。
1450 0
|
.NET 开发框架 索引
|
C# SQL
【转】去除.Net页面中的ViewState乱码
C# code using System;using System.Data;using System.Configuration;using System.Web;using System.Web.
798 0
|
3月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
41 0
|
1月前
|
开发框架 前端开发 .NET
进入ASP .net mvc的世界
进入ASP .net mvc的世界
29 0
|
1月前
|
开发框架 前端开发 .NET
C# .NET面试系列六:ASP.NET MVC
<h2>ASP.NET MVC #### 1. MVC 中的 TempData\ViewBag\ViewData 区别? 在ASP.NET MVC中,TempData、ViewBag 和 ViewData 都是用于在控制器和视图之间传递数据的机制,但它们有一些区别。 <b>TempData:</b> 1、生命周期 ```c# TempData 的生命周期是短暂的,数据只在当前请求和下一次请求之间有效。一旦数据被读取,它就会被标记为已读,下一次请求时就会被清除。 ``` 2、用途 ```c# 主要用于在两个动作之间传递数据,例如在一个动作中设置 TempData,然后在重定向到另
99 5