溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ASP.NET中怎么處理復(fù)合控件事件

發(fā)布時(shí)間:2021-07-15 15:43:06 來(lái)源:億速云 閱讀:135 作者:Leah 欄目:編程語(yǔ)言

本篇文章給大家分享的是有關(guān)ASP.NET中怎么處理復(fù)合控件事件,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來(lái)看看吧。

(1) 直接實(shí)現(xiàn)按鈕事件

在控件中(以下代碼并非實(shí)現(xiàn)復(fù)合控件)直接實(shí)現(xiàn)事件則無(wú)需自定義事件,如下代碼(如果對(duì)數(shù)據(jù)回傳有些不熟悉的話,可先看第三篇,希望對(duì)你有幫助)

ASP.NET控件開發(fā)基礎(chǔ)示例一(只列出局部代碼,具體可在文章***下載代碼)

void IPostBackEventHandler.RaisePostBackEvent(string eventArgument)  {  if (eventArgument == "Previous")  PreviousText = "你點(diǎn)擊了PreviousText按鈕";  else if (eventArgument == "Next")  NextText = "你點(diǎn)擊了NextText按鈕";  }   protected override void RenderContents(HtmlTextWriter writer)  {  writer.AddAttribute(HtmlTextWriterAttribute.Onclick, Page.GetPostBackEventReference(this, "Previous"));  writer.RenderBeginTag(HtmlTextWriterTag.Button);  writer.Write(this.PreviousText);  writer.RenderEndTag();   writer.AddAttribute(HtmlTextWriterAttribute.Onclick, Page.GetPostBackEventReference(this, "Next"));  writer.RenderBeginTag(HtmlTextWriterTag.Button);  writer.Write(this.NextText);  writer.RenderEndTag();  }

還記得第三篇時(shí)示例一中下面的代碼嗎?此控件中只觸發(fā)了一個(gè)事件,所以無(wú)需根據(jù)服務(wù)器傳遞的參數(shù)來(lái)判斷出發(fā)哪個(gè)事件

//實(shí)現(xiàn)RaisePostBackEvent方法,處理回發(fā)事件  public void RaisePostBackEvent(string eventArgument)  {  OnClick(EventArgs.Empty);  }

RaisePostBackEvent方法有一個(gè)eventArgument參數(shù)用來(lái)傳遞事件數(shù)據(jù).代碼實(shí)現(xiàn)了一個(gè)空參數(shù)傳遞(eventArgument參數(shù)為空)的事件OnClick(EventArgs.Empty)

再比較一下示例一的代碼,因?yàn)槠溆玫搅藘蓚€(gè)按鈕

Page.GetPostBackEventReference方法用來(lái)傳遞參數(shù)

RaisePostBackEvent方法則以傳遞參數(shù)來(lái)判斷觸發(fā)哪個(gè)按鈕

小結(jié):

在控件中直接實(shí)現(xiàn)按鈕事件,則無(wú)需定義自定義事件,但別忘了在RaisePostBackEvent方法中根據(jù)傳遞過來(lái)的不同參數(shù)來(lái)加以判斷.

(2)以自定義事件實(shí)現(xiàn)

根據(jù)示例一上面的代碼加上自定義委托和事件,如下代碼(只列出局部代碼,具體可在文章***下載代碼)

ASP.NET控件開發(fā)基礎(chǔ)示例二

void IPostBackEventHandler.RaisePostBackEvent(string eventArgument)  {  if (eventArgument == "Previous")  OnClickPrevious(EventArgs.Empty);  else if (eventArgument == "Next")  OnClickNext(EventArgs.Empty);  }

調(diào)用代碼如下

protected void NavButtons2_1_ClickPrevious(object sender, EventArgs e)  {  Label1.Text = "你點(diǎn)擊了PreviousText按鈕";  }   protected void NavButtons2_1_ClickNext(object sender, EventArgs e)  {  Label1.Text = "你點(diǎn)擊了NextText按鈕";  }

小結(jié):在示例一的基礎(chǔ)上去除直接實(shí)現(xiàn)好的按鈕事件,然后自定義事件.

再次提醒如果大家對(duì)回發(fā)事件,還請(qǐng)?jiān)賲⒖家恍┪恼孪扰宄?或者也可以看看我寫的第三篇文章.

好了,上面講的都非復(fù)合控件,但復(fù)合控件實(shí)現(xiàn)起來(lái)卻很相似,或者可以說更加簡(jiǎn)單.

下面先來(lái)看個(gè)簡(jiǎn)單的示例(大家知道button按鈕有CommandName屬性和CommandArgument屬性)

ASP.NET控件開發(fā)基礎(chǔ)示例三

﹤%@ Page Language="C#" %﹥   ﹤!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"﹥   ﹤script runat="server"﹥   protected void Button1_Click(object sender, EventArgs e)  {  Label1.Text = "你點(diǎn)擊了左按鈕";  }   protected void Button2_Click(object sender, EventArgs e)  {  Label1.Text = "你點(diǎn)擊了右按鈕";  }   protected void btn_command(object sender, CommandEventArgs e)  {  switch (e.CommandName)  {  case "left":  Label2.Text = "你點(diǎn)擊了左按鈕";  break;  case "right":  Label2.Text = "你點(diǎn)擊了右按鈕";  break;  }  }   protected void btn2_command(object sender, CommandEventArgs e)  {  switch (e.CommandName)  {  case "left":  Button1_Click(this, e);  break;  case "right":  Button2_Click(this, e);  break;  }  }  ﹤/script﹥   ﹤html xmlns="http://www.w3.org/1999/xhtml" ﹥  ﹤head runat="server"﹥  ﹤title﹥無(wú)標(biāo)題頁(yè)﹤/title﹥  ﹤/head﹥  ﹤body﹥  ﹤form id="form1" runat="server"﹥  ﹤div﹥  ﹤asp:Button ID="Button1" runat="server"   OnClick="Button1_Click" Text="左按鈕" /﹥  ﹤asp:Button ID="Button2" runat="server" Text="右按鈕"  OnClick="Button2_Click" /﹥﹤br /﹥  ﹤br /﹥  ﹤asp:Label ID="Label1" runat="server"﹥﹤/asp:Label﹥﹤br /﹥  ﹤br /﹥  ﹤asp:Button ID="Button3" runat="server" Text="左按鈕"   CommandName="left" OnCommand="btn_command" /﹥  ﹤asp:Button ID="Button4" runat="server" Text="右按鈕" OnCommand="btn_command" CommandName="right" /﹥﹤br /﹥  ﹤br /﹥  ﹤asp:Label ID="Label2" runat="server"﹥﹤/asp:Label﹥﹤br /﹥  ﹤br /﹥  ﹤asp:Button ID="Button5" runat="server" Text="左按鈕"   CommandName="left" OnCommand="btn2_command" /﹥  ﹤asp:Button ID="Button6" runat="server" Text="右按鈕" OnCommand="btn2_command" CommandName="right" /﹥﹤/div﹥  ﹤/form﹥  ﹤/body﹥  ﹤/html﹥

以上代碼以三種方式來(lái)實(shí)現(xiàn)按鈕的觸發(fā)事件.這里本應(yīng)該再舉一個(gè)數(shù)據(jù)綁定控件如(DataList控件的使用)的一個(gè)例子的一個(gè)例子的,這里目的只為了說明冒泡法的使用,冒泡法在DataList等數(shù)據(jù)綁定控定控件中最能體現(xiàn)出來(lái).

那我們先來(lái)看下,在ASP.NET復(fù)合控件中怎么做?

1.直接實(shí)現(xiàn)按鈕事件

2.以自定義事件實(shí)現(xiàn)

(1)以下為微軟網(wǎng)站的示例代碼,如下代碼

ASP.NET控件開發(fā)基礎(chǔ)示例四

namespace CompositionSampleControls  {   public class Composition2 : Control, INamingContainer  {   public int Value  {  get {  this.EnsureChildControls();  return Int32.Parse(((TextBox)Controls[1]).Text);  }  set {  this.EnsureChildControls();  ((TextBox)Controls[1]).Text = value.ToString();  }  }   protected override void CreateChildControls()  {   // Add Literal Control   this.Controls.Add(new LiteralControl("﹤h4﹥" + "Value: "));   // Add Textbox   TextBox box = new TextBox();  box.Text = "0";  this.Controls.Add(box);   // Add Literal Control   this.Controls.Add(new LiteralControl("﹤/h4﹥"));   // Add "Add" Button   Button addButton = new Button();  addButton.Text = "Add";  addButton.Click += new EventHandler(this.AddBtn_Click);  this.Controls.Add(addButton);   // Add Literal Control   this.Controls.Add(new LiteralControl(" | "));   // Add "Subtract" Button   Button subtractButton = new Button();  subtractButton.Text = "Subtract";  subtractButton.Click += new EventHandler(this.SubtractBtn_Click);  this.Controls.Add(subtractButton);   }   private void AddBtn_Click(Object sender, EventArgs e)  {  this.Value++;  }   private void SubtractBtn_Click(Object sender, EventArgs e)  {  this.Value--;  }  }  }

因?yàn)閮?nèi)部事件已經(jīng)實(shí)現(xiàn)好了,所以比較簡(jiǎn)單,相信大家都看的懂。

再看復(fù)合控件的自定義事件,這里才是我們所要講的重點(diǎn).通常我們提倡在復(fù)合控件中采用冒泡法實(shí)現(xiàn)事件的上傳,上一篇已經(jīng)說過了,復(fù)合控件是一個(gè)樹結(jié)構(gòu)的控件,最典型的就是asp.net的數(shù)據(jù)邦定控件(特殊的復(fù)合控件)了如DataList,此控件有很多以Command結(jié)尾的事件,我們剛開始學(xué)這個(gè)控件的時(shí)候,總要考慮,如何在此控件中實(shí)現(xiàn)按鈕事件,所采用的就是我們常說的"事件冒泡",當(dāng)然還有另一種方法,應(yīng)該說是普通的實(shí)現(xiàn)方法,asp.net服務(wù)器控件開發(fā)技術(shù)與示例稱之為包含法,下面我們以例子來(lái)說明上面兩種方法.

1.包含法

還是以微軟的快速入門教程的代碼為例.與上面的代碼對(duì)比有幾處變動(dòng),如下

注意粗體字,自定義事件為復(fù)合控件頂層的事件,而非其子控件button按鈕的事件,button按鈕的事件需調(diào)用頂層事件處理程序.即實(shí)現(xiàn)子控件事件上傳的過程.

ASP.NET控件開發(fā)基礎(chǔ)示例五

//自定義事件  public event EventHandler Change;  //自定義事件處理程序  protected void OnChange(EventArgs e) { Change(this, e); }  //子控件事件處理程序調(diào)用頂層事件處理程序,此處需注意  private void AddBtn_Click(Object sender, EventArgs e)   { this.Value++; OnChange(EventArgs.Empty); }

2.ASP.NET復(fù)合控件事件冒泡法

上面已經(jīng)介紹過了,并且MSDN也已經(jīng)作出了詳細(xì)的解釋,控件可以將其定義的事件上傳到控件頂層,在引發(fā)事件時(shí)處理事件,了解冒泡法,你需要了解以下兩個(gè)方法

protected virtual bool OnBubbleEvent(     object source,     EventArgs args  );  protected void RaiseBubbleEvent(     object source,     EventArgs args   );

RaiseBubbleEvent不可重寫,用于向上傳遞數(shù)據(jù)

要引發(fā)冒泡事件,控件必重寫 OnBubbleEvent 看OnBubbleEvent方法,看下面代碼

你需要先熟悉一下CommandEventArgs,其為Command事件提供了數(shù)據(jù),通過其可以訪問控件命令名稱和參數(shù),并根據(jù)不同參數(shù)和名稱觸發(fā)不同事件.其下代碼為上一篇登錄控件例子實(shí)現(xiàn)事件冒泡的方法,具體代碼可在***下載,且CreateChildControls方法中的觸發(fā)事件的控件無(wú)須添加一個(gè)事件委托

 addButton.Click += new EventHandler(this.AddBtn_Click);     protected override bool OnBubbleEvent(object source, EventArgs e) {            bool handled = false;          if (e is CommandEventArgs) {              CommandEventArgs ce = (CommandEventArgs)e;             if (ce.CommandName == "Logon") {                 OnLogon(EventArgs.Empty);                 handled = true;                     }                }              return handled;                      }

你也可以為控件定義的事件定義事件冒泡,引發(fā)該時(shí)間則必須調(diào)用RaiseBubbleEvent,示例三就是具體的例子使用

protected virtual void OnCommand(CommandEventArgs e) {       CommandEventHandler handler = (CommandEventHandler)Events[EventCommand];              if (handler != null)                  handler(this,e);               // The Command event is bubbled up the control hierarchy.              RaiseBubbleEvent(this, e);          }

本次講的重點(diǎn)在于冒泡法的使用,但我卻用很多篇幅介紹寫前面的東西,主要目的是為了讓大家用復(fù)合控件與非符合控件進(jìn)行比較,總的來(lái)說復(fù)合控件為我們帶來(lái)了便利,不用實(shí)現(xiàn)IPostBackEventHandler接口,簡(jiǎn)化了操作.如果大家熟悉事件回傳機(jī)制,則不難了解冒泡法的使用.***還是要注意一點(diǎn)的是復(fù)合控件是一個(gè)樹級(jí)的控件,即由子控件組成的一個(gè)控件

以上就是ASP.NET中怎么處理復(fù)合控件事件,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI