由於畢業後工作沒有對接到專業問題,導致四五年沒有碰過Winform程序了。突然由於工作問題,為了方便自己,所以想自己寫寫小winform小軟件,用於自己使用。在使用ComboBox控件時,遇到了重新綁定賦值出問題的情況。
錯誤代碼如下:
if (CustomerBLL.select().Rows.Count > 0) { cbTcid.Items.Clear(); cbTcid.DataSource = CustomerBLL.select(); cbTcid.ValueMember = "Cid"; cbTcid.DisplayMember = "Cpname"; } else { return; }
正常情況下,對於數據重新賦值的或者綁定數據源的時候,為了防止數據出現問題,都會先清空原來數據,所以就這樣寫了,但是沒有相當恰恰這樣寫就出現問題了。 於是在網上找了一下。發現有人是這樣操作的。【如下】
網上查找方法如下:
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; }但是最後我嘗試了一下,在下次綁定數據源的時候,不清空上次的數據,是否可以呢?於是成功了。
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; }而且最主要的是,在綁定數據源之前的數據,也自動清空了。是否真是這樣呢,還是如何呢?難道說這個ComboBox控件在下次綁定時候回自動清空,其他控件呢?歡迎大家討論,而且此方法是否會出現代碼不規范呢?由於我的是小數據,遇到大數據是否可行呢,希望大家說說自己的建議。