在90年代初,Microsoft為Web程序員提供的 Active Server Pages(ASP)革命性地改變了Web的編程。它可以利用十分易用的模型在Web服務器上動態生成HTML,並且很容易的實現了對數據庫的訪問,就當時來說,這是一項多麼吸引人的技術,包括現在Internet上的許多web站點都是用Asp寫的,我的同事前輩們更是玩Asp的高手,經歷這麼多年而不衰,可見他的成功。
但是,技術是在不斷的發展著,引用某位Net專家的話講――如今Web編程的狀態還是落後的。因此Microsoft提出了第二代編程模型――Web窗體。Web窗體模型作為Asp.net的一部分,而Asp.net又是.Net框架的一個部分。他的編程模型是基於事件的,使用他更像是在進行Windows窗體編程,這一點也正是我決定去學習使用他的一個重要原因,也胡亂看了一些這方面的書,寫這篇文章的目的也就是和各位Asp.net初學者和還沒有為用戶控件添加過自定義事件的同行分享一下經驗。
廢話少說,下面就讓我們先建立一個用戶控件吧,這裡就用一個簡單登錄用戶控件來做演示。
先來看看用戶控件的前台代碼(LogInOutControl.ascx文件):
<%@ Control Language="c#" AutoEventWireup="false" Codebehind="LogInOutControl.ascx.cs" Inherits="ZZ.LogInOutControl" TargetSchema="http://schemas.microsoft.com/intellisense/ie5"%>
<TABLE id="Table1" style="FONT-SIZE: 9pt; WIDTH: 183px; HEIGHT: 125px" cellSpacing="1"
cellPadding="1" width="183" align="center" border="1">
<TR>
<TD height="20">
<asp:Label id="LabelUser" runat="server">用戶:</asp:Label>
<asp:TextBox id="TextBoxUserName" Width="128px" runat="server"></asp:TextBox></TD>
</TR>
<TR>
<TD height="20"><FONT face="宋體">
<asp:Label id="LabelPassword" runat="server">密碼:</asp:Label>
<asp:TextBox id="TextBoxPassword" Width="128px" runat="server" TextMode="Password"></asp:TextBox></FONT></TD>
</TR>
<TR>
<TD align="center" height="20"><FONT face="宋體">
<asp:Button id="ButtonLogIn" Width="50px" Text="登錄" runat="server"></asp:Button>
<asp:Button id="ButtonLogOut" Width="49px" Text="注銷" runat="server"></asp:Button></FONT></TD>
</TR>
</TABLE>
我們簡單簡單的放了兩個Label,兩個TextBox,兩個Button以及一個Html表。
接下去就是為LogInOutControl.ascx.cs文件添加代碼了。
首先定義一個delegate,其中LogInOutEventArgs類是從EventArgs類繼承,
public delegate void LogInOutClickHandler(object sender,LogInOutEventArgs e);
我覺得把這個delegate放在LogInOutControl類外面更為合適。
接下去為控件聲明了LogInOutClick事件,如下:
public event LogInOutClickHandler LogInOutClick;
另外為了更好的使用屬性,加了Language枚舉,
private Language language;
當然外部通過public Language Lg {get;set;}屬性來訪問。目的就是改變或者獲取當前控件的顯示。
接下去就是定義控件事件觸發函數OnLogInOutClick,由按鈕單擊事件處理函數來完成對用戶控件事件的觸發。