[英]winform C# DataGridView How to Update Columns bound to Generic List
[英]C# Update combobox bound to generic list
我的表單上有一個組合框,它綁定到一個通用的字符串列表,如下所示:
private List<string> mAllianceList = new List<string>();
private void FillAllianceList()
{
// Add alliance name to member alliance list
foreach (Village alliance in alliances)
{
mAllianceList.Add(alliance.AllianceName);
}
// Bind alliance combobox to alliance list
this.cboAlliances.DataSource = mAllianceList;
}
然后,用戶可以在組合框中添加或移除項目。
我在其他地方讀到,通過簡單地添加或刪除通用列表中的項目,組合框的內容應該自動更新; 如果我對它使用Sort(),應該會發生同樣的事情。
但由於某種原因,我無法做到這一點。 我可以看到組合框的DataSource屬性在添加/刪除/排序項時正確更新,但組合框中顯示的內容不是DataSource屬性中的內容。
我肯定錯過了什么或做錯了什么。
提前致謝!
編輯:
我選擇的答案解決了添加和刪除的問題,但是BindingList對象無法排序,這對我來說是必要的。 我找到了一個解決方案,通過繼承BindingList和添加排序功能來構建自定義類,但我想知道在我的情況下是否有更簡單的解決方案。
關於如何輕松解決這個問題的任何建議?
最簡單的方法是簡單地使用BindingList,如下所示:
private List<string> mAllianceList = new List<string>();
private BindingList<string> bindingList;
private void FillAllianceList()
{
// Add alliance name to member alliance list
foreach (Village alliance in alliances)
{
mAllianceList.Add(alliance.AllianceName);
}
bindingList = new BindingList<string>(mAllianceList);
// Bind alliance combobox to alliance list
this.cboAlliances.DataSource = bindingList;
}
然后,從現在開始,只需處理綁定列表即可添加和刪除項目。 這將從List和ComboBox中刪除它。
編輯:為了回答你關於排序的問題,我想最簡單的(但可能是“hacky”)方式是這樣的:
mAllianceList.Sort();
bindingList = new BindingList<string>(mAllianceList);
this.cboAlliances.DataSource = bindingList;
所以基本上,排序后,您創建一個新的綁定列表並重置數據源。 也許有更優雅的方式來解決這個問題,但這應該有用。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.