ASP.NET的用户控件

本文介绍如何在ASP.NET中创建用户控件,控件属性的动态修改以及控件的事件出发机制。

简介
ASP.NET的服务端控件使得Web开发工作变得更为简单,功能更为强大。我们介绍过如何在ASP.NET页面中使用服务端控件。但是,如果服务端没有所要求的控件时该怎么办呢?

当然,ASP.NET不会给你变出一个莫须有的控件。事实上,可以动手作自己的控件来取代.NET提供的控件。这种控件就是用户控件,也正是本文讨论的话题。

编写第一个用户控件
有人认为,知道如何使用服务端控件可不一定说明编写用户控件是件容易的事。事实上,编写一个基本用户控件(有时也称之为pagelets)并让ASP.NET页面象使用服务端控件那样使用这些控件的确是件简单的事。这里有一个简单示例:

basic.ascx
<p>
This is a user control... really!
</p>

这就是一个用户控件!看到这里,我想你会说我该不是喝醉了,头脑不清楚吧。

但这段代码的确就是易于被使用的一个用户控件。尽管这个控件没有作什么事,却是关于什么是用户控件的一个很好说明。事情并不象想像得那么复杂。注意后缀.ascx,它告诉网页这是一个用户控件。它没有什么特别含义,只是不让IIS去直接执行这段代码。

现在我们来创建一个用户控件,看下面的例子: 

default .aspx 
< %@ Page Language = " VB "  % >
< %@ Register TagPrefix = " asp101samps "  TagName = " SomeText "
Src
= " basic.ascx "  % >

< html >
< head >
< title > ASP.NET User Control Sample  -  Basic </ title >
</ head >
< body bgcolor = " #FFFFFF " >

< asp101samps:SomeText runat = " server "   />

</ body >
</ html >

这段代码输出标准HTML页面,显示用户控件里的文字而不是标记。
那么它是怎么实现的呢?关键就在注册(Register)说明。要注册控件,先要定义三个属性:

TagPrefix
定义控件位置的命名空间。有了命名空间制约,就可以在同一个网页里使用不同功能的同名控件。

TagName
指向所使用控件的名字。在同一个命名空间里的控件名是唯一的。控件名一般都表明控件的功能。

Src
指向控件的资源文件。资源文件使用虚路径("control.ascx" 或 "/path/control.ascx"),不能使用物理路径("C:/path/control.ascx.")。

控件注册之后,就可以象其它服务端控件一样被使用。通过定义目标前缀(TagPrefix)和目标名(TagName),就可以象使用服务端内建控件一样地进行使用。同时也确定了使用服务端运行(runat="server")方式。下面是网页调用用户控件的基本方式:
<TagPrefix:TagName runat="server" />

二、给用户控件增加属性并赋值
下面我给控件加上两个属性,一个是color,另一个是text。

properties.ascx 
< script language = " VB "  runat = " server " >
Public  Color  As   String   =   " black "
Public  Text  As   String   =   " This is a user control... really! "
</ script >

< p >
< font color = " <%= Color %> " >
< % =  Text % >
</ font >
</ p >

这样就可以使用和改变控件的色彩和文字了。可以在初始化时赋值,还可以动态地修改这二个属性。

在同一个网页里可以重复调用这个控件并使用不同的属性值:

properties.aspx 
< %@ Page Language = " VB "  % >
< %@ Register TagPrefix = " asp101samps "  TagName = " SomeText "
Src
= " properties.ascx "  % >

< script language = " VB "  runat = " server " >
Sub Page_Load(Sender As Object, E As EventArgs)
UserCtrl1.Color 
= "green"
UserCtrl1.Text 
= "This control's properties were " _
& "set programmatically!"
End Sub

</ script >

< html >
< head >
< title > ASP.NET User Control Sample  -  Properties </ title >
</ head >
< body bgcolor = " #FFFFFF " >

< asp101samps:SomeText runat = " server "   />

< asp101samps:SomeText Color = " red "  runat = " server "   />

< asp101samps:SomeText Text = " This is quite cool! "  runat = " server "   />

< asp101samps:SomeText Color = " blue "  Text = " Ain't It? "  runat = " server "   />

< asp101samps:SomeText id = " UserCtrl1 "  runat = " server "   />

</ body >
</ html >

还想再好些,用户控件是否能够有事件句柄呢?
用户控件几乎可以作任何事。下面的代码示范控件如何触发Page_Load事件。有了事件句柄,就不用多写其它的维护代码来控制控件的运行。控件可以自己触发事件。

在下面的代码中,封装了一个ASP的textbox控件。我将我的控件名属性与textbox的内容挂钩。

 

events.ascx 
< script language = " VB "  runat = " server " >
Sub Page_Load(Src As Object, E As EventArgs)
Dim strInitialText As String = "Please Enter a Name!"

If Page.IsPostBack Then
If txtName.Text = strInitialText
txtName.Text 
= ""
End If
Else
txtName.Text 
= strInitialText
End If
End Sub


Public   Property Name As String
Get
Return txtName.Text
End Get
Set
txtName.Text 
= Value
End Set
End Property

</ script >

Name: 
< asp:textbox id = " txtName "  runat = " server "   />

< asp:RequiredFieldValidator ControlToValidate = " txtName "
id
= " valtxtName "  Display = " Dynamic "  runat = server >
Please Enter a Name!
</ asp:RequiredFieldValidator >


events.aspx 
< %@ Page Language = " VB "  ClientTarget = " downlevel "  % >
< %@ Register TagPrefix = " asp101samps "  TagName = " SomeText "
Src
= " properties.ascx "  % >
< %@ Register TagPrefix = " asp101samps "  TagName = " TextBox "
Src
= " events.ascx "  % >

< script language = " VB "  runat = " server " >
Sub Page_Load(Sender As Object, E As EventArgs)
txtLabel.Text 
= ""

' The textbox control handles it's own stuff
'
 in it's own Page_Load event handler.
End Sub


Sub btnSubmit_Click(Sender As Object, E As EventArgs)
' Sets the label to the textbox's text
txtLabel.Text = txtName.Name

' I don't need to worry about validation since
'
 my user control does it for me.
End Sub

</ script >

< html >
< head >
< title > ASP.NET User Control Sample  -  Validation  &  Events </ title >
</ head >
< body bgcolor = " #FFFFFF " >

< form runat = " server " >

< asp101samps:TextBox id = " txtName "  runat = " server "   />

< br  />

< asp:button id = " btnSubmit "  onClick = " btnSubmit_Click "
text
= " Submit "  runat = " server "   />

</ form >

< asp101samps:SomeText id = " txtLabel "  runat = " server "   />

</ body >
</ html >

这就是关于用户控件和应用的说明。无论你认为它是否简单,它肯定比使用传统ASP要容易。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值