自定義UpdatePanelTrigger

大家在使用UpdatePanel的時候有沒有遇到過這種情況呢?

  頁面上放置着3到4的UpdatePanel,它們互相獨立,並且UpdateMode都是Condition,這意味着沒有哪個UpdatePanel每次都會更新。大多數UpdatePanel都是由某個控件回發而更新,但是其中的一個例外。它沒有哪個控件來觸發它,它有自己的一套邏輯來判斷是否更新。這段邏輯獨立於其他控件。

  理論上,這段邏輯可以放在頁面的某個生命週期裏進行判斷,例如OnLoad。但是如果,這個判斷甚至必須放在PreRenderComplete之後呢?再者,如果我們真的很想把判斷是否更新的邏輯給獨立與頁面的生命週期的階段呢?

  那麼我們可以自己定義一個UpdatePanel觸發器。

  UpdatePanel觸發器的作用自然是用於觸發某個UpdatePanel的更新。在ASP.NET AJAX中,我們最常見的UpdatePanel觸發器就是AsyncPostBackTrigger和PostBackTrigger。但是在某些需要的時候,我們可以定義自己的觸發器。

  如果要定義一個UpdatePanel觸發器,我們必須繼承UpdatePanelTrigger抽象類,並實現它的HasTriggered方法。UpdatePanelTrigger還有一個virtual方法就是Initialize。這個方法會在UpdatePanel的OnInit或OnLoad階段時調用,它的實現如果要涉及到生命週期方面的問題,則必須注意這一點。HasTriggered方法會在頁面Render時——其實是在ASP.NET AJAX自定義的輸出方法中被調用。我們可以在這裏實現自己的邏輯。

  我們現在就來實現一個ProgramicTrigger,用於解決掀先前提出的問題。這個ProgramicTrigge的實現很簡單,只有寥寥數行代碼:

ProgramicTrigger
public class ProgramicTrigger : UpdatePanelTrigger { private string _CheckMethod = null; public string CheckMethod { get { return _CheckMethod; } set { _CheckMethod = value; } } protected override bool HasTriggered() { if (this._CheckMethod != null) { Page page = this.Owner.Page; MethodInfo methodInfo = page.GetType().GetMethod(this._CheckMethod); return (bool)methodInfo.Invoke(page, null); } return false; } }

 

  在HasTriggered方法中,如果用戶指定了CheckMethod屬性,則使用反射調用定義在頁面中的相應方法,得到是否刷新的結果。其實在一開始,我並不想使用反射,而是想定義一個事件,在事件中進行判斷。可惜如果使用了事件,在編輯模式下就無法使用XML來指定響應事件的方法了——對於非控件的對象,VS的編輯模式只能指定屬性。

  ProgramicTrigger使用起來自然也非常方便:

aspx
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional" ChildrenAsTriggers="false"> <ContentTemplate> <%= DateTime.Now %> <asp:Button ID="Button1" runat="server" Text="Button" /> </ContentTemplate> <Triggers> <ext:ProgramicTrigger CheckMethod="CheckMethod" /> </Triggers> </asp:UpdatePanel>
aspx.cs
public bool CheckMethod() { // ... }

 

  您可以嘗試在CheckMethod中給出不同的實現,然後點擊頁面中的按鈕,察看頁面上顯示的時間是否變化。

  ProgramicTrigger只是最簡單的示例,如果需要的話,您不妨在開發過程中也自定義一個UpdatePanel觸發器?

備註:本文引用自http://www.cnblogs.com/JeffreyZhao/archive/2007/03/19/Customize_UpdatePanel_Trigger.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章