ASP.NET中實(shí)現(xiàn)定制自己的委托和事件參數(shù)類
本文實(shí)例講述了ASP.NET中實(shí)現(xiàn)定制自己的委托和事件參數(shù)類的方法,對(duì)于學(xué)習(xí)ASP.NET有很好的參考借鑒價(jià)值。具體方法如下:
一般在實(shí)際開發(fā)中,對(duì)于事件不需要傳遞數(shù)據(jù)信息時(shí),像上面的KingTextBox控件的事件,在引發(fā)事件時(shí)傳遞的參數(shù)為EventArgs.Empty,如下所示:
OnTextChanged(EventArgs.Empty);
這是因?yàn)榭丶﨣ingTextBox的TextChanged事件比較簡單,這里不需要參數(shù)對(duì)象傳遞數(shù)據(jù)。但像一些復(fù)雜的控件比如GridView的按鈕命令事件,必須得有參數(shù)命令表示單擊了哪個(gè)按鈕;翻頁事件,需要EventArgs參數(shù)對(duì)象把當(dāng)前頁信息傳遞到頁面后臺(tái)代碼的事件體的第二個(gè)參數(shù)中,然后開發(fā)人員根據(jù)此頁參數(shù)從數(shù)據(jù)庫取得對(duì)應(yīng)頁的數(shù)據(jù);還有像ItemDataBound事件,也需要把當(dāng)前Row信息和索引等數(shù)據(jù)作為EventArgs參數(shù)傳遞到事件實(shí)例中。
當(dāng)遇到以上這些情況,我們就需要定義自己的事件參數(shù)類和委托,而不使用默認(rèn)的System.EventArgs類。下面就以Grid控件的翻頁功能說明一下定義事件參數(shù)類和委托的方法,請(qǐng)看以下代碼:
/// <summary> /// /// </summary> public delegate void GridPageChangedEventHandler(object source, GridPage ChangedEventArgs e); public class GridPageChangedEventArgs : System.EventArgs { public GridPageChangedEventArgs() { } private int intCurrentPageIndex; public new int CurrentPageIndex { get { return intCurrentPageIndex; } set { intCurrentPageIndex = value; } } private int intPageCount; public new int PageCount { get { return intPageCount; } set { intPageCount = value; } } private int intPageSize; public new int PageSize { get { return intPageSize; } set { intPageSize = value; } } }
以上代碼定義了一個(gè)存儲(chǔ)翻頁相關(guān)信息的參數(shù)類,此參數(shù)類派生于System.EventArgs類,在這里系統(tǒng)不強(qiáng)制要求一定繼承于該類,不繼承它也是可以的,但繼承于該類有一點(diǎn)好處。先看一下System.EventArgs基類的代碼:
/// <summary> /// /// </summary> public class EventArgs { //表示沒有事件數(shù)據(jù)的事件 public static readonly EventArgs Empty; //初始化 System.EventArgs 類的新實(shí)例 public EventArgs(); }
EventArgs中除了一個(gè)構(gòu)造方法外,還有一個(gè)它本身類型的Empty屬性,從這里可以知道前面在調(diào)用時(shí)通過OnTextChanged(EventArgs.Empty);格式,把EventArgs.Empty作為空參數(shù)傳入事件引發(fā)方法時(shí)的用途了。這里要說明的是如果我們的GridPageChangedEventArgs類是從EventArgs繼承而來,則不但可以傳遞GridPageChangedEventArgs類對(duì)象,而且可以使用GridPageChangedEventArgs.Empty的形式傳遞空參數(shù)對(duì)象。
在GridPageChangedEventArgs方法體中定義了一些屬性;分別表示當(dāng)前頁(CurrentPageIndex)、頁總數(shù)(PageCount)和頁尺寸(PageSize)。這些都是我們自定義的頁信息數(shù)據(jù)。
代碼中的這句:
public delegate void GridPageChangedEventHandler(object source, GridPage ChangedEventArgs e);
定義了一個(gè)委托GridPageChangedEventHandler。該委托可以指定這樣的一個(gè)事件方法:第一個(gè)參數(shù)為object類型,第二個(gè)參數(shù)即為上面我們定義的頁參數(shù)類對(duì)象GridPageChanged EventArgs。在注冊(cè)事件時(shí),該委托可以保證在頁面后面代碼中自動(dòng)產(chǎn)生的事件體的兩個(gè)參數(shù)類型與自己的兩個(gè)參數(shù)類型一致。下面是在頁面中注冊(cè)的事件后臺(tái)代碼:
protected void Grid1_PageIndexChanged(object source,GridPageChangedEventArgs e) { int intCurrentPageIndex = e.CurrentPageIndex; int intPageSize = e.PageSize; //獲取數(shù)據(jù)邏輯 }
可以看到第二個(gè)參數(shù)類型即我們定義的GridDocPageChangedEventArgs類型,在事件方法體中,可以直接通過e.CurrentPageIndex和e.PageSize獲取數(shù)據(jù),這種應(yīng)用就比較多了。
現(xiàn)在頁參數(shù)對(duì)象和委托定義好了,下面說一下在主控件內(nèi)部是如何應(yīng)用它們的。聲明事件代碼如下:
/// <summary> /// /// </summary> private new static readonly object EventPageIndexChanged = new object(); [Category("Action"), Description("翻頁事件")] public event GridPageChangedEventHandler PageIndexChanged { add { base.Events.AddHandler(Grid.EventPageIndexChanged, value); } remove { base.Events.RemoveHandler(Grid.EventPageIndexChanged, value); } }
這里繼續(xù)采用高效率事件集合列表對(duì)象base.Events,事件的名稱為PageIndexChanged,委托類型為之前我們定義的委托類型GridPageChangedEventHandler。
引發(fā)事件的核心代碼如下:
/// <summary> /// /// </summary> protected override bool OnBubbleEvent(object source, EventArgs e) { bool handled = false; if (e is GridCommandEventArgs) { if ((((GridCommandEventArgs)(e)).CommandSource) is LinkButton) { LinkButton lb=((LinkButton)(((GridCommandEventArgs)(e)). Command Source)); if (lb.CommandName == "Page") { if (lb.CommandArgument == "ButtonFirst") { GridPageChangedEventArgs ee = new GridPageChangedEventArgs(); if (this.CurrentPageIndex != 0) { this.CurrentPageIndex = 0; ee.CurrentPageIndex = this.CurrentPageIndex; ee.PageCount = this.PageCount; ee.PageSize = this.PageSize; this.OnPageIndexChanged(ee); } handled = true; } if (lb.CommandArgument == "ButtonNext") { GridPageChangedEventArgs ee = new GridPageChangedEventArgs(); if (this.CurrentPageIndex < this.PageCount - 1) { this.CurrentPageIndex += 1; ee.CurrentPageIndex = this.CurrentPageIndex; ee.PageCount = this.PageCount; ee.PageSize = this.PageSize; this.OnPageIndexChanged(ee); } handled = true; } if (lb.CommandArgument == "ButtonPrev") { GridPageChangedEventArgs ee = new GridPageChangedEventArgs(); if (this.CurrentPageIndex > 0) { this.CurrentPageIndex -= 1; ee.CurrentPageIndex = this.CurrentPageIndex; ee.PageCount = this.PageCount; ee.PageSize = this.PageSize; this.OnPageIndexChanged(ee); } handled = true; } if (lb.CommandArgument == "ButtonLast") { GridPageChangedEventArgs ee = new GridPageChangedEventArgs(); if (this.CurrentPageIndex != this.PageCount - 1) { this.CurrentPageIndex = this.PageCount - 1; ee.CurrentPageIndex = this.CurrentPageIndex; ee.PageCount = this.PageCount; ee.PageSize = this.PageSize; this.OnPageIndexChanged(ee); } handled = true; } } } } return handled || base.OnBubbleEvent(source, e); }
以上OnBubbleEvent方法主要應(yīng)用于復(fù)合控件中,采用冒泡形式處理子控件事件,后面介紹復(fù)合控件冒泡處理事件機(jī)制時(shí)再詳細(xì)講解此方法。另外,在控件的翻頁欄中預(yù)先放置了四個(gè)翻頁功能的按鈕,分別表示“首頁”、“上一頁”、“下一頁”、“末頁”,并設(shè)置它們的屬性CommandName都為“Page”,CommandArgument分別為“ButtonFirst”,“ButtonPrev”,“ButtonNext”,“ButtonLast”。
這樣就可以根據(jù)按鈕的命令和參數(shù)確定執(zhí)行什么樣的邏輯。這里僅拿按鈕“下一頁”(Command="Page"&&CommandArgument="ButtonNext")為例解釋一下代碼邏輯:
/// <summary> /// /// </summary> if (lb.CommandArgument == "ButtonNext") { GridPageChangedEventArgs ee = new GridPageChangedEventArgs(); if (this.CurrentPageIndex < this.PageCount - 1) { this.CurrentPageIndex += 1; ee.CurrentPageIndex = this.CurrentPageIndex; ee.PageCount = this.PageCount; ee.PageSize = this.PageSize; this.OnPageIndexChanged(ee); } handled = true; }
代碼中首先定義一個(gè)頁參數(shù)類對(duì)象,然后通過條件語句判斷當(dāng)前是否是最后一頁,如果不是最后一頁,則從主控件上讀取當(dāng)前頁信息(當(dāng)前頁、頁數(shù)、頁記錄數(shù)),并賦值給GridPageChangedEventArgs對(duì)象,然后以頁參數(shù)對(duì)象作為參數(shù)調(diào)用this.OnPageIndexChanged方法引發(fā)事件。另外,注意LinkButton的CommandName和CommandArgument屬性的組合用法。
最后,看一下OnPageIndexChanged方法代碼:
/// <summary> /// </summary> protected new void OnPageIndexChanged(GridPageChangedEventArgs e) { GridPageChangedEventHandler handler1 = (GridPageChangedEventHandler)base. Events[Grid.EventPageIndexChanged]; if (handler1 != null) { handler1(this, e); } }
此方法的功能是從base.Events對(duì)象中取出以Grid.EventPageIndexChanged為Key的事件引用句柄,假如句柄不為null(開發(fā)人員注冊(cè)了翻頁事件),則引發(fā)事件方法體。
最后,說明非常重要的一點(diǎn):如果自定義了事件參數(shù)類,并要求在開發(fā)人員注冊(cè)的事件體中自動(dòng)顯示改變參數(shù)對(duì)象的類型,如:
protected void Grid1_PageIndexChanged(object source, GridPageChangedEventArgs e) { //… … }
其中的第二個(gè)參數(shù)顯示為GridPageChangedEventArgs類型,而不是默認(rèn)的EventArgs類型,我們也必須定義自己的委托(如本例定義了委托GridPageChangedEventHandler);而默認(rèn)的委托EventHandler對(duì)應(yīng)的參數(shù)類型為基類System.EventArgs,即如果這里將默認(rèn)的委托EventHandler和GridPageChangedEventArgs類一起使用的話,則生成以下的代碼語句:
protected void Grid1_PageIndexChanged(object source, EventArgs e) { //… … }
可以看出參數(shù)變?yōu)镋ventArgs類型了。這樣就不能利用我們自己定義的GridPage ChangedEventArgs類中的數(shù)據(jù)了。雖然可以使用(GridPageChangedEventArgs)EventArgs的方式轉(zhuǎn)換一下也可以取得GridPageChangedEventArgs對(duì)象中的數(shù)據(jù),但據(jù)筆者了解還沒有開發(fā)人員這么用,因?yàn)闆]有人知道還有個(gè)GridPageChangedEventArgs類。
本文主要講解如何定制自己的參數(shù)類和委托,并以Grid的分頁功能為例演示其在實(shí)際開發(fā)中的應(yīng)用。
感興趣的讀者可以參考本文所述調(diào)試運(yùn)行本文示例,相信會(huì)有新的收獲。
- Asp.Net 不同的OnClick事件區(qū)別小結(jié)(onserverclick,onclientclick)
- ASP.NET的事件模型(很適合學(xué)習(xí)的文章)
- Asp.net TextBox的TextChanged事件使用介紹
- Asp.net 圖片文件防盜鏈(尊重勞動(dòng)成果)及BeginRequest事件學(xué)習(xí)
- ASP.NET 頁面事件執(zhí)行順序介紹
- 詳解ASP.NET頁面生命周期事件
- php 模擬 asp.net webFrom 按鈕提交事件的思路及代碼
- asp.net錯(cuò)誤處理Application_Error事件示例
- asp.net錯(cuò)誤捕獲(錯(cuò)誤處理)page_error事件使用方法
- ASP.NET頁面按鈕單擊事件失效的解決方法
- asp.net頁面觸發(fā)事件panel滾動(dòng)條高度不變的實(shí)現(xiàn)方法
- asp.net在事件中啟動(dòng)線程來打開一個(gè)頁面的實(shí)現(xiàn)方法
- asp.net中c#自定義事件的實(shí)現(xiàn)方法詳解
- ASP.NET中事件如何依次發(fā)生?
相關(guān)文章
EFCore 通過實(shí)體Model生成創(chuàng)建SQL Server數(shù)據(jù)庫表腳本
這篇文章主要介紹了EFCore 通過實(shí)體Model生成創(chuàng)建SQL Server數(shù)據(jù)庫表腳本的示例,幫助大家更好的理解和學(xué)習(xí)使用.net框架,感興趣的朋友可以了解下2021-03-03.Net 文本框?qū)崿F(xiàn)內(nèi)容提示的實(shí)例代碼(仿Google、Baidu)
這篇文章主要介紹了.Net 文本框?qū)崿F(xiàn)內(nèi)容提示的實(shí)例代碼,需要的朋友可以參考下2014-02-02asp.net mvc下拉框Html.DropDownList 和DropDownListFor的常用方法
這篇文章主要介紹了asp.net mvc下拉框Html.DropDownList 和DropDownListFor的常用方法 ,需要的朋友可以參考下2014-10-10ASP.NET.4.5.1+MVC5.0設(shè)置系統(tǒng)角色與權(quán)限(一)
這篇文章主要介紹了ASP.NET.4.5.1+MVC5.0設(shè)置系統(tǒng)角色與權(quán)限的部分內(nèi)容,后續(xù)我們將繼續(xù)討論這個(gè)話題,希望小伙伴們喜歡。2015-01-01asp net core 2.1中如何使用jwt(從原理到精通)
這篇文章主要給大家介紹了關(guān)于asp net core 2.1中如何使用jwt(從原理到精通)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧2018-11-11.NET實(shí)現(xiàn)微信公共平臺(tái)上傳下載多媒體文件
這篇文章主要介紹了.NET實(shí)現(xiàn)微信公共平臺(tái)上傳下載多媒體文件的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-07-07