ASP.NET入门随想之服务器控件模型

asp.net|服务器|控件

  他迷上了珍珠奶茶。说实话,以前他一直觉得珍珠奶茶挺蠢的,真不知道是那一个天才的点子,居然把粉圆和泡沫红茶搅和在一起,还加上一根那么滑稽的超大吸管;妹妹刚迷上珍珠奶茶的时候,他还挺嗤之以鼻的呢。但这天以后,他几乎天天都会去买一杯珍珠奶茶,愈喝愈觉得珍珠奶茶的风味很特别,的确满好喝的。知道他迷上珍珠奶茶,妹妹还笑他:"早跟你说好喝你不信,男生就是迟钝。"
                                      -- 管家琪《珍珠奶茶的诱惑》

  ■ 面向对象的粉圆 - 服务器控件模型

  XHTML的一个重要目标就是将结构与表现分离,如:<div id="author">老燕</div>;但从一个动态网站的角度来看,需要进一步将网页结构与内容分离,即:<div id="author"><!--动态数据--></div>,相比较而言,网页结构是静态,内容是动态。

  charly的《内容发布系统的开发》引发我对一段往事的追忆,作者讨论的命题是如何用动态数据生成静态页面,方法是用数据替换模板中指定标签。引申开来就是ASP程序员非常久远的梦想--代码与页面分离,即避免出现<div id="author"> <%=author%></div>之类HTML代码与ASP程序代码混杂在一块的情况,,而解决之道,用的就是charly描述的方法--正则表达式替换。

  如果用静态/动态这个角度去分析一个.aspx文件,可以将其分成两部份:一部份是静态的连续的文本,如:<html>……<body>;另一部份是动态的特殊标签,如:<asp:TextBox id="txtName" runat="server" />。两者以是否拥有属性runat="server"为判断标准。ASP.NET将后一部份称之为服务器控件,程序员以服务器控件为对象模型来定义Web应用程序的用户界面,控制用户交互;而前一部份在运行时也将被创建成一种特殊的控件--LiteralControl。

  如果用ASP面向过程的方法来处理所谓的服务器控件,就是根据用户的需求直接生成对应的HTML代码;而在ASP.NET中,程序员与HTML代码被抽象的面向对象的服务器控件概念隔离开来。既然面向对象,服务器控件就应该拥有属性(property)来描述自己的状态;用方法(method)描述自己的动作;需要事件(event)来触发方法,改变状态,最后自动生成相应的HTML代码。

  当然我们不需要从头来构架这个模型,所有的服务器控件,包括Page类,都直接或间接继承于System.Web.UI.Control类,而显示为HTML表单元素的控件,往往又继承于System.Web.UI.WebControl类,称为Web控件。下例是一个简单的自定义控件范例,访问该例的TestMyControls.aspx页,查看源代码会发现控件对应的Hhtml代码为"1"。

// MyControls.cs 自定义控件集
using System;
using System.Web.UI;
namespace essay{
 public class MyFirstControl:Control{ //输出属性Number绝对值控件
  private int _number;
  public int Number{ //Number定义属性
   get {return _number;}
   set {_number=value;}
  }
  //重写Control.Render方法,生成控件对应的HTML代码
  protected override void Render(HtmlTextWriter writer) {
   writer.Write(Math.Abs(Number));
  }
 }
}
// TestMyControls.aspx页面文件,<%Register%>注册自定义控件集
// <mc: ……>在页面增加自定义控件并将属性Number值设为-1
<%@ Register TagPrefix="mc" Namespace="essay" Assembly="essay" %>
<HTML><HEAD></HEAD><body>
<form runat="server">
<mc:MyFirstControl id="test1" Number="-1" runat="server" />
</form></body></HTML>  ■ 葛玲是谁? - 服务器控件的状态保持

  若干年前有一个火腿肠广告,对话如下:

  吕丽萍:冬宝,在想啥呢?

  葛 优:想葛玲

  吕丽萍:别想了,我给你介绍一位新朋友--DUDU牌火腿肠

  吕丽萍:(过一会儿)还想葛玲吗?

  葛 优:葛玲是谁?

  人机交互设计的一个重要内容是交互工作流,而实现交互工作流的前提是状态保持,否则就会出现"葛玲是谁"这样的幽默。

  控件可以利用传统的cookies、session、隐藏控件等方法来存储状态值,在随想八》中我们已经探讨过视图状态(ViewState)的作用和原理,本质上,ASP.NET创造出的有状态、连续的页面状态保持机制是通过页面隐藏数据。接下来我们通过改造上例进一步研究利用视图状态来完成控件状态保持的细节。

// MyControls.cs 自定义控件集
……
public class MyFirstControl:Control{ //输出属性Number绝对值控件
 private int _number;
 public int Number{……}
 //增加属性NumberInViewState,用以存取属性Number的视图状态值
 public int NumberInViewState{
  get{
   object o = ViewState["NumberInViewState"];
   return (o==null)?0:(int)o;
  }
  set { ViewState["NumberInViewState"]=value; }
 }
 protected override void Render(HtmlTextWriter writer){……}
}
……
// TestMyControls.aspx页面文件
<html>
……
<%@ Page Language="C#" %>
<script runat="server">
protected override void OnLoad(EventArgs e)
{
 test1.NumberInViewState--; //视图状态相应值自减1
 test1.Number = test1.NumberInViewState; //自定义控件值与视图值保持一致
 base.OnLoad(e);
}
</script>
<form runat="server">
<mc:MyFirstControl id="test1" runat="server" />
<input type="submit" />
</form></body></html>
  ■ 换杯子还是换粉圆? - 控件树与服务器控件的生命周期

  在运行期,页面框架会在杯子里放入指定的服务器控件类实例,当然它们不是胡乱堆积在一块,而是组合成一颗控件树,图10-2为例2页面的控件树模型,我们可以通过控件的ID或在树中的位置控制控件,也可以增加或删除控件。

  在假想的有状态、连续的页面前提,意味着在初始请求后,页面必须保存每一个控件的状态,在回传(PostBack)后,首先是恢复控件原来的状态,再处理新的请求。也就是说,每一个客户端对同一个页面的连续N次请求,相当于向奶茶铺连续要了N杯同一品种的奶茶,第一杯珍珠奶茶中粉圆状态是默认的,从顾客提出第二杯奶茶请求起,伙计必须先把这杯中粉圆状态拨弄成与端给顾客时的上一杯状态一模一样,然后根据顾客新的事件进行调整。如图10-2。详细过程请查阅MSDN的《控件执行生命周期》。


  这种无中生有的交互工作流实现方法是要付出代价的,作为编程模型而言,程序员可以在服务器控件的抽象概念上轻松实现,但对整个系统的性能而言,ASP.NET并未对客户端和服务器端做过多少负载性能优化,用合金枪头(我的一位网友)的话来说,"如果就连选择籍贯省市的下拉框都要用服务器控件来提交一下,同时刷新页面的话,那的确很恶心"。

  一个很自然的想法是为什么对每一次请求我们都要把整个杯子换掉呢?如果仅仅是换掉几个粉圆和一小部份奶茶,将大大改善系统性能,这就是Ajax技术的出发点。

时间: 2024-12-26 09:22:59

ASP.NET入门随想之服务器控件模型的相关文章

ASP.NET入门随想之抽象的力量

 ? ASP.NET入门随想之抽象的力量 小 时看过一故事:三书生欲进京赶考,问一老僧三人前景如何,老僧端坐如山,最后缓缓伸出一指.于是三书生路上争论不休,不明老僧指哪一人会黄榜题名,不料后 来三人同时高中,高兴之余,不禁对老僧的权威起了疑心.三人衣锦返乡后,追问老僧,老僧及端坐如山,缓缓曰:一指表示三人皆中,三人立马晕倒. ■ASP的编程思想 -写八股文 MS在java技术的冲击下匆忙推出ASP技术.要不是因为WinServer操作系统的霸主地位,粗陋的ASP不太可能在OO推行二十几年.C++

ASP.NET入门教程:HTML服务器控件

  前面简单介绍完了ASP.NET 2.0之后,我们简单介绍一些HTML服务器控件.上一篇文章:ASP.NET入门教程:ASP.NET 2.0导航 HTML 服务器控件是服务器可理解的 HTML 标签. HTML 服务器控件 ASP.NET 文件中的 HTML 元素默认作为文本进行处理.为了使这些元素可编程化,需要向 HTML 元素添加 runat="server" 属性.该属性指示该元素应作为服务器控件进行处理. 注释:所有 HTML 服务器控件必须位于带有 runat="

ASP.NET入门之HTML服务器控件概述_实用技巧

ASP.NET 中的HTML服务器控件是服务器可理解的HTML标签. ASP.NET 文件中的 HTML 元素默认作为文本进行处理.为了使这些元素可编程化,需要向 HTML 元素添加 runat="server" 属性.该属性指示该元素应作为服务器控件进行处理. 注意: 1.所有 HTML 服务器控件必须位于带有 runat="server" 属性的标签内! 2.ASP.NET 要求所有 HTML 元素必须正确关闭和嵌套. HTML服务器空间及相关描述如下表所示:

ASP.NET入门随想之明明白白我的心

asp.net 有一群说着同样语言的人,计划修一座高耸入云的高塔直达天庭,以证明族群团结的力量,塔很快就初具规模.这下可惊动天庭的神,他想这人和神都成邻居了,还怎么去统治人类?于是便施魔法扰乱人们的语言,使他们无法沟通,于是高塔再也无法继续修建. ■ 明明白白我的心 - 人机交互(Human-Computer Interaction) 博客园里有一篇<给妈妈写程序>感人肺腑,说的是作者常常为了指导50出头的妈妈完成COPY之类的操作耗尽心思,最后为其定做一个只需点击两下的程序,由此推出UI设计

ASP.NET入门随想之代言人

asp.net 本报讯 著名品牌服务器控件(Control)携手奥运冠军客户端HTML标签作为形象代言人,新形象以"极速体验"为主题,既诠释了服务器控件本身强大的信息处理能力,也表现客户端HTML标签希望用灵动和亲切来证明自己的决心与态度. ■ 内与外 - property与attribute 近日Google发布除英文外的唯一名称--谷歌,中国用户一片哗然, 暂且不论这个谷歌是不是比胡弋更合适,但Google想借此阐述产品内涵,取悦中国用户之心路人皆知:今年WEB2.0引无数风投竞折

ASP.NET入门随想六之大航海家

asp.net 多隆云:我和韦春花的关系是很纯洁的:网易称其和迷蝶女友的关系是培训双向选择制:杨振宁言<易经>思想阻碍了中国近代科学的发展:逻辑学家论:概念间的关系有五种,即同一.包含.交叉.分离.互斥.而康托尔却认为:关系是有序偶. ■ 我要懒+笨 - 程序设计的终极目标 前不久社区里出现题为<这样的程序员是否算是一个合格的程序员?>的热贴,楼主言一手下编码花时间比别人多但代码规范健壮,设问这样的程序员是否可以留用且如何用?顿时掀起一片哗然,展开在中国这个特定的环境下何为程序设计

ASP.NET入门随想之检票的老太太

asp.net 德国足协告诫那些可能前往德国观看2006年世界杯赛的球迷要提防假票,不要从非代理商和票贩子手中购票.世界杯门票都是高科技产品,门票被植入微芯片,只有通过合法途径取得门票的球迷才能入场.假票现象在近些年的足球大赛上泛滥成灾,德国足协希望能通过宣传避免世界杯球迷成为其受害者. ■ 验明正身 - 数据有效性 世界杯万人瞩目但门票有限,所以有人造假有人买假,安联球场的大门前站几位检票员必不可少,而我们的程序有时也一样.当你接到一个累积数年的数据表时,发现单单联系电话都有23种格式时,你是

ASP.NET入门随想之多态、接口与委托

asp.net     曾几何时,我们居住的陆地沉睡在海底,大陆也紧密的联系在一起,千百年过去了七大洲的地壳板块在缓缓移动,喜马拉雅山在慢慢增高,世界在变,唯一不变的是变化. ■ 软件开发的悖论 - 把变化变成计划 在软件开发活动的过程中,常被一个悖论所缠绕:不写码就搞不清该做什么:搞不清做什么又不知道该如何写码. 人的思维是很随意的东西,不同的人,或同一个人的不同阶段,对同一件事情的看法都会有差异,可谓是远看成岭侧成峰,远近高低各不同.随意再加上变化,常常引起项目流产或工期大大拖延. 之所以会

ASP.NET编程入门随想之宽容(修改版)

asp.net|编程 相关文章:ASP.NET编程入门随想之宽容 古老的山谷村民生活富足,守旧老人维护着经典和秩序.一位不满现状的漂泊者却宣称外面有更好的世界在等着大家,并鼓动村民跟随前往.但守旧老人的威严和律法的神圣压制了村民的躁动,漂泊者也被处死.一天灾难降临山谷.尽管守旧老人依然试图维护经受村民的求生欲望挑战的律法.但暴动还是发生,老人们被击败,新的道路和新的生活被村民找到.怀着感恩之心,后人把以前的漂泊者奉为先知,尽管他早已尸骨无存. -- 房龙<宽容•序言> ■ 宽容 – W3C 的