共用方式為


BindingSource 元件架構

透過 BindingSource 元件,您可以將所有的 Windows Form 控制項全部繫結至資料來源。

BindingSource 元件簡化了將控制項繫結至資料來源的程序,同時提供了優於舊式資料繫結的下列各項特點:

  • 可以讓商務物件 (Business Object) 使用設計階段繫結。

  • 可以在設計階段封裝 CurrencyManager 功能和公開 (Expose) CurrencyManager 事件。

  • 藉由為原本不支援清單變更告知的資料來源,提供清單變更告知功能,可以簡化支援 IBindingList 介面的清單建立程序。

  • IBindingList.AddNew 方法提供了擴充性點。

  • 在資料來源和控制項之間提供了間接取值 (Indirection) 層級。 當資料來源可以在執行階段變更時,間接取值非常重要。

  • 可以與其他資料相關的 Windows Form 控制項 (特別是 BindingNavigatorDataGridView 控制項) 相互操作。

基於這些理由,BindingSource 元件是當您將 Windows Form 控制項繫結至資料來源時的慣用方式。

BindingSource 功能

BindingSource 元件提供了數種可將控制項繫結至資料的功能。 利用這些功能,幾乎不太需要撰寫程式碼,就可以實作大部分的資料繫結案例。

BindingSource 元件藉由提供一致的介面做為存取各種不同資料來源之用,即可完成此項工作。 這意味著不論是繫結至何種型別,都是使用相同的程序。 例如,可以將 DataSource 屬性附加至 DataSet 或商務物件。這兩種情況都是使用同一組屬性、方法和事件來管理資料來源。

BindingSource 元件所提供的一致介面大幅簡化了資料至控制項的繫結程序。 對於提供變更告知的資料來源型別,BindingSource 元件會自動在控制項與資料來源之間傳遞變更。 對於不提供變更告知的資料來源型別,會提供可讓您引發變更告知的事件。 下列是 BindingSource 元件支援的功能:

間接

BindingSource 元件在資料來源和控制項之間,提供了可以進行間接取值的層級。 您不是將控制項直接繫結至資料來源,而是先將控制項繫結至 BindingSource,然後再將資料來源附加至 BindingSource 元件的 DataSource 屬性。

利用這個間接取值層級,您不需要重新設定控制項繫結即可變更資料來源, 因而能夠:

貨幣管理

BindingSource 元件會實作 ICurrencyManagerProvider 介面,來為您處理貨幣管理。 透過 ICurrencyManagerProvider 介面,除了其他繫結至相同 DataMemberBindingSource 的 Currency 管理員以外,您還可以存取 BindingSource 的 Currency 管理員。

BindingSource 元件可封裝 CurrencyManager 功能和公開最常用的 CurrencyManager 屬性和事件。 下表說明部分與貨幣管理相關的成員。

資料來源做為清單。

BindingSource 元件可實作 IBindingListViewITypedList 介面。 利用這個實作,您不需要任何外部儲存體即可將 BindingSource 元件本身當做資料來源使用。

BindingSource 元件附加至資料來源時,它會將資料來源公開為清單。

您可以將 DataSource 屬性設定為數種資料來源, 包括型別、物件和型別清單。 產生的資料來源將公開為清單。 下表顯示部分的通用資料來源以及產生的清單評估。

DataSource 屬性

列出結果

null 參考 (在 Visual Basic 中為 Nothing)

物件的空 IBindingList。 藉由加入項目即可將清單設為已加入之項目的型別。

含有 DataMember 集合的 null 參考 (在 Visual Basic 中為 Nothing)

不支援,會引發 ArgumentException

非清單型別或 型別 "T" 的物件

"T" 型別的空 IBindingList

陣列執行個體

包含陣列項目的 IBindingList

IEnumerable 執行個體

包含 IEnumerable 項目的 IBindingList

包含 "T" 型別的清單執行個體

包含 "T" 型別的 IBindingList

此外,也可以將 DataSource 設定為其他清單型別 (例如 IListSourceITypedList),並且將由 BindingSource 適當地處理這些型別。 在這種情況下,清單中所包含的型別應該要有預設的建構函式。

BindingSource 做為 IBindingList

BindingSource 元件提供存取和管理基礎資料的成員做為 IBindingList。 下表說明這些成員中的一部分。

成員

描述

List 屬性

取得經由評估 DataSourceDataMember 屬性而得到的清單。

AddNew 方法

將新的項目加入至基礎清單中。 套用至實作 IBindingList 介面的資料來源 (也就是將 AllowNew 屬性設為 true)。

建立自訂項目。

您可以處理 AddingNew 事件以提供自己的項目建立邏輯。 在 BindingSource 加入新物件之前會發生 AddingNew 事件。 這個事件是發生於呼叫 AddNew 方法之後,但基礎清單加入新項目之前。 藉由處理這個事件,不需從 BindingSource 類別衍生即可提供建立自訂項目行為。 如需詳細資訊,請參閱 HOW TO:使用 Windows Form BindingSource 自訂加入項目

建立異動項目。

BindingSource 元件可實作 ICancelAddNew 介面,此介面可建立異動項目。 隨著呼叫 AddNew 而暫時建立了新項目之後,這個加入項目的動作可利用下列方式加以認可或復原:

  • EndNew 方法會明確認可這項暫止的加入動作。

  • 執行其他集合作業 (例如插入、移除或移動) 即隱含認可這項暫止的加入動作。

  • CancelNew 方法會復原暫止的加入動作 (如果此方法尚未經過認可的話)。

IEnumerable 支援

BindingSource 元件可將控制項繫結至 IEnumerable 資料來源。 利用這個元件,可繫結至資料來源 (例如 System.Data.SqlClient.SqlDataReader)。

IEnumerable 資料來源指派給 BindingSource 元件時,BindingSource 會建立 IBindingList 並將 IEnumerable 資料來源的內容加入至清單。

設計階段支援

有些物件型別無法在設計階段建立,例如,建立自 Factory 類別的物件或是由 Web 服務傳回的物件。 有時候,您可能必須在設計階段將控制項繫結至這些型別,即使記憶體中並沒有控制項可以繫結的物件。 例如,此時可能必須使用自訂型別的公用屬性名稱來標記 DataGridView 控制項的資料行行首。

為了支援這樣的案例,BindingSource 元件將會支援繫結至 Type。 當您將 Type 指派給 DataSource 屬性時,BindingSource 元件會建立 Type 項目的空 BindingList<T>。 如果型別的屬性或結構描述在設計階段或執行階段中出現,那麼後續繫結至 BindingSource 元件的所有控制項都將會收到警示。 如需詳細資訊,請參閱 HOW TO:將 Windows Form 控制項繫結至型別

靜態 ListBindingHelper 方法

System.Windows.Forms.BindingContextSystem.Windows.Forms.CurrencyManagerBindingSource 型別都共用一般邏輯,藉此從成對的 DataSource/DataMember 組合產生清單。 此外,這個通用邏輯會透過下列 static 方法進行公開,以供控制項作者和其他協力廠商使用:

使用 IBindingListView 介面進行排序和篩選。

BindingSource 元件可實作 IBindingListView 介面,而此介面可延伸 IBindingList 介面。 IBindingList 提供單一資料行排序,而 IBindingListView 則提供進階排序和篩選。 如果資料來源也會實作其中一個介面,您可以使用 IBindingListView 來排序和篩選資料來源中的項目。 BindingSource 元件並不提供這些成員的參考實作。 而呼叫會轉送到底層清單。

下表說明在排序和篩選時所使用的屬性。

成員

描述

Filter 屬性

如果資料來源是 IBindingListView,則可取得或設定運算式,此運算式是用於篩選檢視中的資料列。

Sort 屬性

如果資料來源是 IBindingList,則可取得或設定資料行名稱,此資料行名稱是用於排序以及排序次序資訊。

-或-

如果資料來源是 IBindingListView 並且支援進階排序,則可取得多重資料行名稱,此資料行名稱是用於排序以及排序次序。

使用 BindingNavigator 進行整合

可以使用 BindingSource 元件將任何 Windows Form 控制項繫結至資料來源,但 BindingNavigator 控制項是特別設計用來與 BindingSource 元件搭配使用。 BindingNavigator 控制項所提供的介面用於控制 BindingSource 元件的目前項目。 根據預設,BindingNavigator 控制項所提供的按鈕是對應到 BindingSource 元件上的巡覽方法。 如需詳細資訊,請參閱 HOW TO:使用 Windows Form BindingNavigator 控制項巡覽資料

請參閱

工作

HOW TO:將 Windows Form 控制項繫結至型別

HOW TO:使用 BindingSource 反映 Windows Form 控制項中的資料來源更新

參考

BindingSource 元件概觀

BindingSource

BindingNavigator

其他資源

BindingNavigator 控制項 (Windows Form)

Windows Form 資料繫結

在 Windows Form 上使用的控制項