ASP.NET中PostBack和ViewState

开发 后端
本文介绍ASP.NET中PostBack和ViewState,对PostBack进行了一些研究,现在看来研究的还是不够深入。

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是通过下面的代码添加的:

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

而不是在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开发最有力的武器。

【编辑推荐】

  1. 微软发布ASP.NET MVC 2预览版 多项功能更新
  2. ASP.NET服务器自定义控件安全准则
  3. ASP.NET编程规范之编码规范浅析
  4. 关于ASP.NET Session的一点认识
  5. ASP.NET编程工具ASP.NET Web Matrix详细介绍
责任编辑:佚名 来源: IT专家网
相关推荐

2009-08-04 12:29:57

ViewState概念ASP.NET

2009-07-20 15:19:52

ViewState本质ASP.NET

2009-07-28 16:42:02

ViewState技术ASP.NET应用

2009-08-04 17:00:09

ASP.NET禁用Vi

2009-07-28 13:39:44

加载ViewStateASP.NET

2009-08-05 15:01:04

ASP.NET应用Vi

2009-06-09 11:37:51

ViewStateViewDataASP.NET

2009-07-27 13:25:15

Postback程序处ASP.NET

2009-08-04 17:49:31

Web Page生命周ASP.NET Pos

2009-07-27 12:22:03

ASP.NET和ASPASP.NET入门教程

2009-07-29 16:08:07

ASP和ASP.NET

2009-08-05 18:14:52

ASP.NET 2.0

2009-08-04 10:51:09

Attributes和ASP.NET页面

2009-07-27 14:46:16

XML和ASP.NET

2009-07-22 17:45:35

ASP.NET教程

2009-08-03 14:22:33

什么是ASP.NET

2009-07-28 17:17:19

ASP.NET概述

2009-07-22 18:03:00

ASP.NET ASP

2009-06-12 09:24:34

ASP.NET窗体ASP.NET MVC

2009-07-31 09:39:59

ASP.NET和URL
点赞
收藏

51CTO技术栈公众号