用户控件和自定义控件的比较及在项目中的应用
摘 要
本文档描述了服务器控件的基本概念,以及用户控件和自定义控件在部署、创建、内容和布局、设计期行为、性能几个方面的比较,然后给出一个在项目开发中服务器控件使用的建议,最后给出一个用户控件的创建和调用的例子。 关 键 词 Server Control 服务器控件 User Control 用户控件,ASP.NET服务器控件的一种(一般后缀名为.ASCX文件) Custom Control 自定义控件,ASP.NET服务器空间的一种(一般后缀名为.DLL文件) Deployment 部署,程序的分发 Design Attribute 设计期属性 RAD 快速应用程序开发 修 改 履 历 版本号版本完成日期作者修改内容描述修改处涉及章节
1. 知识背景
1.1服务器控件简介 服务器控件是ASP.NET页面中用来定义WEB应用程序用户界面的组件。服务器控件是Web Forms 编程模式的基本元素。他们构成了一个新的,基于组件的,直观的表单程序的基础,可以简化Web用户界面的开发。这类似与 Microsoft Visual Basic/Borland Delphi等传统RAD开发工具用来简化Windows Forms编程的方法。从更高的层次来说,服务器控件提供了Web应用程序和表示技术隐含的抽象概念 1.2服务器控件的特征和功能
1:服务器控件隐藏了技术中潜在的不一致性和复杂性,给网页开发者创建了一个直观且简单的编程模式
2:服务器控件隐藏了各种浏览器与查看设备之间的不同,包括目标Web应用程序可能需要的不同版本的浏览器。浏览器控件提供了适于目标浏览器内容显示的能力 。
3:服务器控件起到实际组件的作用,提供在组件与其他类应用合作中可能得到的相同好处。
4:服务器控件通过回传(PostBack)和往返(Round-Trip)的方式管理状态
5:服务器控件包含了处理相关Web请求的回传数据及网页开发者处理其服务器端代码中用户输入和用户动作的逻辑模型。
6:服务器控件提供数据绑定模型。
7:服务器控件为开发者提供多种机制定制自己的页面生成(Rending).
8:服务器控件在机器级别(通过 Machine.config文件)或者在Web应用程序级别上(通过Web.config文件)是可配置的。
9:在Visual Sturdio.Net这样的可视化设计期环境中,服务器控件提供了一种快速应用开发(Rapid Application Development,RAD)环境
2. 为什么编写自定义服务器控件
虽然标准ASP.NET服务器控件能解决最常用的应用程序方案,当它不详尽。实际上,有很多方案不能直接用这些控件解决。例如,标准 ASP.NET服务器控件不能解决图像映射,制图功能等。以下是开发服务器控件的几个原因:
1:以多个Web应用程序中可复用的和直观的抽象概念形式封装应用程
序逻辑。
2:创建商业的组件类库,类似与Visual Basic中的Active控件和Delphi
中的VCL控件。
3:在大型工作团队中为分工提供一个明确的机制。例如在工作团队
中的开发者可以通过设计和实现应用程序用户界面的开发工具把控件
组合在一起。
3. 用户控件和自定义控件的异同服务器控件分为用户控件模型和自定义控件,一般而言,用户控件模型适合创建内部,应用程序特定的控件,而自定义控件模型更适合创建通用的和可再分发的控件,
下面从6个方面来说明他们的异同。
3.1部署当在两个控件模型之间进行选择的时候,部署是最重要的考虑因素,自定义控件模型采用大多数应用程序可以使用的配件形式(.DLL形式),为创建可再分发的组件而设计。用户控件模型是为单个应用程序的情况设计的。用户控件必须以源代码形式部署(.ASCX文件),这些需求有增加维护成本的副作用。
3.2创建创建自定义控件的技术与创建用户控件的技术是不相同的,自定义控件是用.NET编程语言通过编写一个从 System.Web.UI.Control类中直接或间接派生的托管类而创建。这里没有对创建自定义控件的提供设计器支持。但是用户控件类间接地从System.Web.UI.Control派生而来,用户控件以.ASCX文件的形式声明性地创建,这类似于设计和开发ASP.NET页面的方式(易于设计和调试)。
3.3内容和布局由于创建机制的不同,用户控件和自定义控件提供不同的内容和布局支持自定义控件非常适用于通过编程方式生成的布局中所表现的动态内容。例如一个具有动态行的数据绑定控件,一个动态节点的控件树。用户控件的布局在.ASCX文件创建时声明,所以当需要固定布局的相对静态的内容时,用户控件是最好的选择.
3.4设计期行为目前,Visual Studio .Net为自定义控件和用户控件提供了相当不同的设计期能力。Visual Studio .Net为自定义控件提供很大程度的设计期支持功能,比如可以支持设计时属性,方法。Visual Studio .Net对用户控件只拥有很少的设计期支持。用户控件并不在属性窗口中显示属性和事件,也不能放到工具箱中。
3.5性能虽然自定义控件和用户控件遵循着不同的创建模型并且有不同的特性,但这两个控件都是从相同的基类(System.Web.UI.Control)间接地派生的,用户控件在实现时声明性,在页面中第一次使用它的时候,用户控件作为普通的服务器控件被解析并编译进配件中。此后用户控件的行为就象任何其它的编译的(或者自定义)控件一样,所以性能上差别不是很大,主要从其他方面来考虑怎么选择这两种控件。
4. 服务器控件开发情况的建议服 务 器 控 件 开 发 情 况 的 建 议情况建议
5 用户控件的开发下面用一个例子来简述一个用户控件的开发过程.(通过把已存在的ASP.NET的部分页面转换成用户控件模型).
Query_UC_Common.ascx源文件
页面到自定义控件需要修改的部分
注:页面到自定义控件需要修改的部分
1:删除标记<html><bodry><head>
2: 把<%@ Page Language="c#" ClassName="RequiredTextField" %>该为<%@ Control Language="c#" ClassName="RequiredTextField" %>
3: 把文件存为.ASCX文件即可
注意:在页面中调用用户控件的说明
1:为用户控件的声明语句,
2:TagPrefix:TagName结合生成一个标签,服务器解析时把它与指定的用户控件关联在一起,这个结合对已注册的每个用户控件必须是唯一的。 3: Src="Query_UC_Common.ascx”为用户控件在位置,可以是相对路径也可以是绝对路径,但是一定是该页面用户可以访问到的由于这个通用查询显示和打印的用户控件涉及的知识点太多,我会在以后专门写个分析报告,跟大家一起来讨论!
界面截图如下:
查询设置界面过滤显示字段
6 参考资料
1:MSDN ONLINE
2:Vs.Net 2002 MSDN
3:Developing ASP.NET Server Controls