程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> 關於.NET >> C#ComboBox控件“設置 DataSource 屬性後無法修改項集合”的解決方法,

C#ComboBox控件“設置 DataSource 屬性後無法修改項集合”的解決方法,

編輯:關於.NET

C#ComboBox控件“設置 DataSource 屬性後無法修改項集合”的解決方法,


由於畢業後工作沒有對接到專業問題,導致四五年沒有碰過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控件在下次綁定時候回自動清空,其他控件呢?歡迎大家討論,而且此方法是否會出現代碼不規范呢?由於我的是小數據,遇到大數據是否可行呢,希望大家說說自己的建議。

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved