国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

ASP.NET用戶控件入門指南

開發 后端
ASP到ASP.NET是一個歷史性的變更。本文對ASP.NET用戶控件做了一番入門介紹。

ASP以及ASP.NET歷史回顧

ASP.NET技術雖然算是從ASP演變而來的,不過使用起來確實是兩碼事。我們先看看這兩個技術的歷史:在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初學者和還沒有為用戶控件添加過自定義事件的同行分享一下經驗。

建立一個簡單的ASP.NET用戶控件

廢話少說,下面就讓我們先建立一個用戶控件吧,這里就用一個簡單登錄用戶控件來做演示。

先來看看用戶控件的前臺代碼(LogInOutControl.ascx文件):

  1. < %@ Control Language="c#" AutoEventWireup="false" Codebehind="LogInOutControl.ascx.cs" Inherits="ZZ.LogInOutControl" TargetSchema="http://schemas.microsoft.com/intellisense/ie5"%> 
  2. < TABLE id="Table1" style="FONT-SIZE: 9pt; WIDTH: 183px; HEIGHT: 125px" cellSpacing="1" 
  3. cellPadding="1" width="183" align="center" border="1"> 
  4. < TR> 
  5.    < TD height="20"> 
  6.     < asp:Label id="LabelUser" runat="server">用戶:< /asp:Label> 
  7.     < asp:TextBox id="TextBoxUserName" Width="128px" runat="server">< /asp:TextBox>< /TD> 
  8. < /TR> 
  9. < TR> 
  10.    < TD height="20">< FONT face="宋體"> 
  11.      < asp:Label id="LabelPassword" runat="server">密碼:< /asp:Label> 
  12.      < asp:TextBox id="TextBoxPassword" Width="128px" runat="server" TextMode="Password">< /asp:TextBox>< /FONT>< /TD> 
  13. < /TR> 
  14. < TR> 
  15.    < TD align="center" height="20">< FONT face="宋體"> 
  16.      < asp:Button id="ButtonLogIn" Width="50px" Text="登錄" runat="server">< /asp:Button> 
  17.      < asp:Button id="ButtonLogOut" Width="49px" Text="注銷" runat="server">< /asp:Button>< /FONT>< /TD> 
  18. < /TR> 
  19. < /TABLE> 

我們簡單的放了兩個Label,兩個TextBox,兩個Button以及一個Html表。

接下去就是為LogInOutControl.ascx.cs文件添加代碼了。

首先定義一個delegate,其中LogInOutEventArgs類是從EventArgs類繼承,

  1. public delegate void LogInOutClickHandler(object sender,LogInOutEventArgs e); 

我覺得把這個delegate放在LogInOutControl類外面更為合適。

接下去為控件聲明了LogInOutClick事件,如下:

  1. public event LogInOutClickHandler LogInOutClick; 

另外為了更好的使用屬性,加了Language枚舉,

  1. private Language language; 

當然外部通過public Language Lg {get;set;}屬性來訪問。目的就是改變或者獲取當前控件的顯示。

接下去就是定義控件事件觸發函數OnLogInOutClick,由按鈕單擊事件處理函數來完成對用戶控件事件的觸發。

ASP.NET用戶控件完整代碼如下:

  1. namespace ZZ  
  2. {  
  3. using System;  
  4. using System.Data;  
  5. using System.Drawing;  
  6. using System.Web;  
  7. using System.Web.UI.WebControls;  
  8. using System.Web.UI.HtmlControls;  
  9.  
  10. // 定義代理  
  11. public delegate void LogInOutClickHandler(object sender,LogInOutEventArgs e);  
  12. public class LogInOutControl : System.Web.UI.UserControl  
  13. {  
  14.    protected System.Web.UI.WebControls.Button ButtonLogIn;  
  15.    protected System.Web.UI.WebControls.TextBox TextBoxUserName;  
  16.    protected System.Web.UI.WebControls.TextBox TextBoxPassword;  
  17.    protected System.Web.UI.WebControls.Button ButtonLogOut;  
  18.    protected System.Web.UI.WebControls.Label LabelUser;  
  19.    protected System.Web.UI.WebControls.Label LabelPassword;  
  20.    public event LogInOutClickHandler LogInOutClick;  
  21.    private Language language;  
  22.    //方法  
  23.    public void ChangeLanguage(Language language)  
  24.    {  
  25.     this.Lg = language;  
  26.    }  
  27.    //屬性  
  28.    public Language Lg  
  29.    {  
  30.     set 
  31.     {  
  32.      if(value!=this.language)  
  33.      {  
  34.       if(value==Language.English)  
  35.       {  
  36.        this.LabelUser.Text = "User:";  
  37.        this.LabelPassword.Text ="Password:";  
  38.        this.ButtonLogIn.Text = "LogIn";  
  39.        this.ButtonLogOut.Text = "LogOut";  
  40.       }  
  41.       else 
  42.       {  
  43.        this.LabelUser.Text = "用戶:";  
  44.        this.LabelPassword.Text ="密碼:";  
  45.        this.ButtonLogIn.Text = "登錄";  
  46.        this.ButtonLogOut.Text = "注銷";  
  47.       }  
  48.      }  
  49.     }  
  50.    }  
  51.    private void Page_Load(object sender, System.EventArgs e)  
  52.    {  
  53.     if(this.LabelUser.Text=="User:")  
  54.       this.language = Language.English;  
  55.      else 
  56.       this.language = Language.Chinese;  
  57.    }  
  58.    private void OnLogInOutClick(object sender,LogInOutEventArgs e)  
  59.    {  
  60.     if(LogInOutClick!=null)  
  61.      LogInOutClick(this,e);  
  62.    }  
  63.    #region Web 窗體設計器生成的代碼  
  64.    override protected void OnInit(EventArgs e)  
  65.    {  
  66.     InitializeComponent();  
  67.     base.OnInit(e);  
  68.    }  
  69. private void InitializeComponent()  
  70.    {  
  71.     this.ButtonLogIn.Click += new System.EventHandler(this.ButtonLogIn_Click);  
  72.     this.ButtonLogOut.Click += new System.EventHandler(this.ButtonLogOut_Click);  
  73.     this.Load += new System.EventHandler(this.Page_Load);  
  74.    }  
  75.    #endregion  
  76.    private void ButtonLogIn_Click(object sender, System.EventArgs e)  
  77.    {  
  78.     OnLogInOutClick(this,new LogInOutEventArgs(LogInClickType.LongIn,CustomValidate(this.TextBoxUserName.Text,this.TextBoxPassword.Text)));  
  79.    }  
  80.    private void ButtonLogOut_Click(object sender, System.EventArgs e)  
  81.    {  
  82.     //注銷代碼省略  
  83.     OnLogInOutClick(this,new LogInOutEventArgs(LogInClickType.LongOut,true));  
  84.    }  
  85.    //驗證函數  
  86.    private bool CustomValidate(string userName,string password)  
  87.    {  
  88.     //驗證代碼省略,假設通過  
  89.     return true;  
  90.    }  
  91. }  
  92. }  

另外一個文件定義了枚舉和參數類:

  1. using System;  
  2. namespace ZZ  
  3. {  
  4. public class LogInOutEventArgs : EventArgs  
  5. {  
  6.    private LogInClickType type;  
  7.    private bool result;  
  8.     
  9.    public LogInOutEventArgs(LogInClickType type,bool result):base()  
  10.    {  
  11.     this.type = type;  
  12.     this.result = result;  
  13.    }  
  14.    public LogInClickType Type  
  15.    {  
  16.     get{return this.type;}  
  17.    }  
  18.    //操作結果,  
  19.    public bool Result  
  20.    {  
  21.     get{return this.result;}  
  22.    }  
  23. }  
  24. //操作類型  
  25. public enum LogInClickType : int 
  26. {  
  27.    LongIn,  
  28.    LongOut  
  29. }  
  30. //定義語言  
  31. public enum Language   
  32. {  
  33.    Chinese,  
  34.    English  
  35. }  

接下去看看在aspx頁面里面使用ASP.NET用戶控件。

新建一個Default.aspx頁面,拖一個LogInOutControl用戶控件到上面。

  1. < %@ Register TagPrefix="uc1" TagName="LogInOutControl" Src="LogInOutControl.ascx" %> 
  2. < %@ Page language="c#" Codebehind="Default.aspx.cs" AutoEventWireup="false" Inherits="ZZ.Default" %> 
  3. < %@ Import Namespace="ZZ" %> 
  4. < HTML> 
  5. < HEAD> 
  6.    < title>WebForm1< /title> 
  7. < /HEAD> 
  8. < body> 
  9.    < form id="Form1" method="post" runat="server"> 
  10.     < FONT face="宋體"> 
  11.      < uc1:LogInOutControl id="LogInOutControl1" runat="server"> 
  12.      < /uc1:LogInOutControl> 
  13.      < asp:Label id="LabelMsg" runat="server">< /asp:Label> 
  14.      < asp:DropDownList id="DropDownList1" runat="server" AutoPostBack="True"> 
  15.       < asp:ListItem Value="0" Selected="True">中文< /asp:ListItem> 
  16.       < asp:ListItem Value="1">英文< /asp:ListItem> 
  17.      < /asp:DropDownList>< /FONT> 
  18.    < /form> 
  19. < /body> 
  20. < /HTML> 

在后臺代碼中添加事件和屬性。

雖然在前臺添加了LogInOutControl1,但是后臺代碼中不會生成protected LogInOutControl LogInOutControl1;這條語句,我覺得很奇怪,不管先加上他。

接著在Page_Load事件中注冊LogInOutClick事件:

  1. this.LogInOutControl1.LogInOutClick += new LogInOutClickHandler(LogInOutControl1_LogInOutClick); 

完整代碼如下:

  1. using System;  
  2. using System.Collections;  
  3. using System.ComponentModel;  
  4. using System.Data;  
  5. using System.Drawing;  
  6. using System.Web;  
  7. using System.Web.SessionState;  
  8. using System.Web.UI;  
  9. using System.Web.UI.WebControls;  
  10. using System.Web.UI.HtmlControls;  
  11.  
  12. namespace ZZ  
  13. {  
  14. public class Default : System.Web.UI.Page  
  15. {  
  16.    protected System.Web.UI.WebControls.Label LabelMsg;  
  17.    protected System.Web.UI.WebControls.DropDownList DropDownList1;  
  18.    protected LogInOutControl LogInOutControl1;  
  19.    private void Page_Load(object sender, System.EventArgs e)  
  20.    {  
  21.     //注冊用戶控件事件  
  22.     this.LogInOutControl1.LogInOutClick += new LogInOutClickHandler(LogInOutControl1_LogInOutClick);  
  23.    }  
  24.    #region Web 窗體設計器生成的代碼  
  25.    override protected void OnInit(EventArgs e)  
  26.    {  
  27.     InitializeComponent();  
  28.     base.OnInit(e);  
  29.    }  
  30.    private void InitializeComponent()  
  31.    {      
  32.     this.DropDownList1.SelectedIndexChanged += new System.EventHandler(this.DropDownList1_SelectedIndexChanged);  
  33.     this.Load += new System.EventHandler(this.Page_Load);  
  34.    }  
  35.    #endregion  
  36.    private void LogInOutControl1_LogInOutClick(object sender, LogInOutEventArgs e)  
  37.    {  
  38.     switch(e.Type)  
  39.     {  
  40.      case LogInClickType.LongIn:  
  41.       this.LabelMsg.Text = "你點擊了登錄按鈕,操作結果:"+e.Result.ToString();  
  42.       break;  
  43.      case LogInClickType.LongOut:  
  44.       this.LabelMsg.Text = "你點擊了注銷按鈕,操作結果:"+e.Result.ToString();  
  45.       break;  
  46.     }  
  47.    }  
  48. private void DropDownList1_SelectedIndexChanged(object sender, System.EventArgs e)  
  49.    {  
  50.     this.LogInOutControl1.Lg = (Language)this.DropDownList1.SelectedIndex;  
  51.     //this.LogInOutControl1.ChangeLanguage((Language)this.DropDownList1.SelectedIndex);  
  52.    }  
  53. }  
  54. }  

當用戶在前臺通過選擇下拉框列表來改變控件的語言,這里通過Lg屬性來完成,不過這里也加了一個方法ChangeLanguage也可以實現同樣的功能。另外,通過點擊登陸或注銷按鈕觸發LogInOutClick事件來給頁面中的LabelMsg.Text屬性賦值從而得到操作結果。

總結,用戶控件為程序員帶來了很高的開發效率和重用性,更是在性能方面有了很大的提高,以前稱為Asp+,其實我認為Asp.net跟Asp沒有什么直接聯系。而且我想做應用程序的朋友和我一樣在開發Web程序時更喜歡采用代碼分離方式,這樣結構更清晰,便與修改和管理。同Asp程序相比,他是編譯型的,引入了面向對象的設計思想,也就不可避免的帶來了他的復雜性,要想開發高水準的Asp.net程序,對于模式的設計,層次結構的劃分,這里還是比較講究的。總之,他更像是在編Windows窗體程序,而不是在寫VB腳本。

【編輯推薦】

  1. 深入研究Repeater控件:***的靈活性
  2. DataList控件入門介紹
  3. DataGrid Web控件運作機制探秘
  4. 小議ASP.NET數據Web控件之間的相似性
  5. 從傳統ASP到ASP.NET的轉變:了解控件
責任編輯:yangsai 來源: 百度空間
相關推薦

2009-08-03 15:08:00

SqlDataSour

2009-08-04 13:38:36

ASP.NET用戶控件

2009-08-10 14:16:59

ASP.NET自定義控

2009-07-27 12:22:03

ASP.NET和ASPASP.NET入門教程

2009-08-19 13:44:00

ASP.NET Lis

2009-07-29 13:50:26

UpdatePanelASP.NET

2009-08-04 10:43:59

ASP.NET控件開發

2009-08-05 15:57:03

ASP.NET控件ID

2009-07-27 17:25:53

ASP.NET驗證控件

2009-08-17 09:24:25

ASP.NET控件

2009-07-27 16:19:59

ASP.NET報表控件

2009-07-27 13:52:36

Panel控件ASP.NET

2009-07-24 10:36:08

ASP.NET控件

2009-07-24 15:41:00

ASP.NET編程入門

2009-08-04 15:58:06

ASP.NET動態控件

2009-09-11 09:09:00

ASP.NETAdRotator控件

2009-07-21 15:50:47

ASP.NET控件JavaScript

2009-08-07 17:49:44

控件設計器

2009-08-07 15:24:16

ASP.NET模板控件

2009-08-04 11:29:14

HTML代碼ASP.NET控件
點贊
收藏

51CTO技術棧公眾號

精品日韩在线观看| 成人av色在线观看| 免费av在线网站| 久久久久久9999| 裸体大乳女做爰69| 久久视频一区| 国产视色精品亚洲一区二区| 成人在线免费观看视频| 欧美怡红院视频一区二区三区| 精品欧美日韩精品| 亚洲精品一区二区三区婷婷月| 幼a在线观看| 欧美在线观看一区| 香蕉97视频观看在线观看| 亚洲精品免费看| 特黄aaaaaaaaa毛片免费视频| 中文字幕亚洲精品在线观看 | 婷婷成人在线| 2018日韩中文字幕| 欧美大奶一区二区| 欧美一区二区三区艳史| 欧美日韩一区二区三区四区不卡| 亚州国产精品久久久| 精品成人自拍视频| 亲爱的老师9免费观看全集电视剧| 影音先锋欧美激情| 97久久精品国产| 欧美猛男同性videos| 国产精品视频专区| 亚洲国产专区校园欧美| 日本在线免费观看一区| 蜜桃久久久久久| 男人天堂a在线| 久久久久久亚洲综合影院红桃| 欧美国产日韩在线播放| 亚洲婷婷在线视频| 丝袜视频国产在线播放| 欧美日韩一区视频| 国产丝袜视频在线播放| 色豆豆成人网| 久久综合亚洲社区| 少妇淫片在线影院| 国产福利一区在线| 日本精品一区二区三区四区 | 国产高清不卡二三区| 99免费视频观看| 一区二区三区免费看视频| 99re在线视频| 在线视频中文亚洲| 欧美老女人另类| 欧美日韩日本网| 91片黄在线观看| 国产呻吟对白刺激无套视频在线| 国产精品久久久久久久久免费桃花| 精品中文一区| 久久国产精品久久精品| 日韩中文字幕| 图片区亚洲欧美小说区| www久久日com| 亚洲国产欧美自拍| 午夜激情成人网| 欧美黑人xxxⅹ高潮交| 极品美女一区二区三区| 国内精品视频免费| 国产最新精品精品你懂的| 在线观看国产中文字幕| 日本韩国欧美国产| 日本高清不卡一区二区三区视频| 韩国精品久久久999| 欧美一区精品| 日韩a∨精品日韩在线观看| 怡红院av一区二区三区| 超碰在线caoporen| 久久成人精品电影| 欧美涩涩网站| 给我免费播放片在线观看| 亚洲一二三四在线观看| 女人让男人操自己视频在线观看| 欧洲精品久久久| 久久电影网站中文字幕| 成人丁香基地| 日韩精品中文字幕在线播放| 国产精品手机在线播放 | 中文文精品字幕一区二区| 91欧美在线视频| 久久全国免费视频| 综合激情视频| 精品视频亚洲| 亚洲精品一区二| 国产精品国产精品国产专区不片| 日本在线视频观看| 欧美伦理91i| 欧美一区免费| 免费裸体美女网站| 日韩午夜在线观看| 亚洲国产合集| 免费的av在线| 欧美中文字幕一区二区三区| 在线观看视频一区二区三区| 欧美中日韩免费视频| 亚洲人成亚洲人成在线观看图片| 秋霞无码一区二区| 99精品国产热久久91蜜凸| 福利小视频在线观看| 神马久久久久久| 在线视频免费在线观看一区二区| 日日摸天天爽天天爽视频| 91精品国产乱| 精品大片一区二区| 免费国产a级片| 日韩免费看网站| 亚洲欧美偷拍自拍| av免费播放| 久久777国产线看观看精品| 久久99精品久久久久久久久久久久 | 欧美在线观看网站| 成人性生交大片免费| 538在线视频| 六月婷婷久久| 色婷婷久久一区二区三区麻豆| 国产 日韩 欧美 综合 一区| 丁香六月激情婷婷| 亚洲天堂一区二区三区| 首页国产欧美久久| 黄色av免费在线| 精品久久一区二区三区蜜桃| 一本大道久久a久久精二百| 亚洲综合色网站| 日韩欧美一级| 每日在线观看av| 亚洲性视频网站| 国产精品影视在线| 9999在线视频| 日韩欧美亚洲在线| 欧美一区二区在线看| 国产视频久久| 午夜激情在线观看| 欧美成人第一区| 日韩一级高清毛片| 日韩精品欧美成人高清一区二区| av免费看在线| 91麻豆国产自产在线观看| 欧美xnxx| 激情五月开心婷婷| 欧美国产日韩精品| 亚洲欧洲日韩女同| 国产探花在线精品| 四虎在线视频| 精品一区久久久久久| 日韩精品一区二区三区视频在线观看 | 成人国产二区| 国产精品一区在线观看| 日韩欧美中文字幕在线播放| 91成人国产| av在线免费网址| 三级在线免费观看| 久久综合国产精品台湾中文娱乐网| 91毛片在线观看| 91精品啪在线观看国产爱臀| 美女黄a一级视频| 91青草视频久久| 69精品人人人人| 国产剧情一区二区| 一区二区中文字幕在线观看| 亚洲电影小说图| 视频一区视频二区视频三区高| 最新国产精品亚洲| 午夜在线成人av| 日韩av一区二区三区| japansex久久高清精品| 天堂在线看视频| 九色视频成人porny| 中文字幕在线精品| 一级日本不卡的影视| 91精品啪在线观看国产81旧版| xxxx成人| 性直播在线观看| 精品免费一区二区三区蜜桃| 国产亚洲人成a一在线v站| 亚洲天堂成人在线观看| 99精品视频免费观看视频| 久久天堂av| 中文在线a在线| 中文字幕成人一区| 2020久久国产精品| 欧美一级日韩不卡播放免费| 久久欧美一区二区| 夜间精品视频| 日韩黄色三级在线观看| 久久久久久高清| 免费看男男www网站入口在线| 97久久久久久| 欧美精品免费播放| 国产中文欧美精品| 91色在线视频| 欧美成人vps| 亚洲欧洲成人自拍| 日韩成人一级片| 婷婷五月色综合香五月| 草莓福利社区在线|