由于畢業(yè)后工作沒有對接到專業(yè)問題,導致四五年沒有碰過Winform程序了。突然由于工作問題,為了方便自己,所以想自己寫寫小winform小軟件,用于自己使用。在使用ComboBox控件時,遇到了重新綁定賦值出問題的情況。
錯誤代碼如下:
1
2
3
4
5
6
7
8
9
10
11
|
if (CustomerBLL.select().Rows.Count > 0) { cbTcid.Items.Clear(); cbTcid.DataSource = CustomerBLL.select(); cbTcid.ValueMember = "Cid" ; cbTcid.DisplayMember = "Cpname" ; } else { return ; } |
正常情況下,對于數(shù)據(jù)重新賦值的或者綁定數(shù)據(jù)源的時候,為了防止數(shù)據(jù)出現(xiàn)問題,都會先清空原來數(shù)據(jù),所以就這樣寫了,但是沒有相當恰恰這樣寫就出現(xiàn)問題了。 于是在網(wǎng)上找了一下。發(fā)現(xiàn)有人是這樣操作的。【如下】
網(wǎng)上查找方法如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
if (CustomerBLL.select().Rows.Count > 0) { // cbTcid.Items.Clear(); if (cbTcid.Items.Count > 0) { cbTcid.DataSource = null ; cbTcid.Items.Clear(); } cbTcid.DataSource = CustomerBLL.select(); cbTcid.ValueMember = "Cid" ; cbTcid.DisplayMember = "Cpname" ; } else { return ; } |
但是最后我嘗試了一下,在下次綁定數(shù)據(jù)源的時候,不清空上次的數(shù)據(jù),是否可以呢?于是成功了。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
if (CustomerBLL.select().Rows.Count > 0) { /*cbTcid.Items.Clear(); if (cbTcid.Items.Count > 0) { cbTcid.DataSource = null; cbTcid.Items.Clear(); }*/ cbTcid.DataSource = CustomerBLL.select(); cbTcid.ValueMember = "Cid" ; cbTcid.DisplayMember = "Cpname" ; } else { return ; } |
而且最主要的是,在綁定數(shù)據(jù)源之前的數(shù)據(jù),也自動清空了。是否真是這樣呢,還是如何呢?難道說這個ComboBox控件在下次綁定時候回自動清空,其他控件呢?歡迎大家討論,而且此方法是否會出現(xiàn)代碼不規(guī)范呢?由于我的是小數(shù)據(jù),遇到大數(shù)據(jù)是否可行呢,希望大家說說自己的建議。
以上所述是小編給大家介紹的C# ComboBox控件“設置 DataSource 屬性后無法修改項集合”的完美解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網(wǎng)站的支持!
原文鏈接:http://www.cnblogs.com/ygyalex/archive/2016/11/03/6027797.html