DataGridView使用之DataGridViewComboBoxColumn

本文介绍了如何在DataGridView中使用DataGridViewComboBoxColumn,通过`init()`方法设置DataSource、DisplayMember和ValueMember属性。在示例中,创建了一个DataTable并填充了选项,然后将这个DataTable绑定到ComboBox列。注意,当设置DataSource时,应使用索引而不是列名,以避免运行时错误。同时强调了数据源字段类型与ComboBox值字段类型的一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

DataGridView使用之DataGridViewComboBoxColumn


private void init()
{
   DataTable dt =getTest();
   int index = -1;
   for (int i = 0; i < this.dtgResult.Columns.Count; i++)
   {
     if (this.dtgResult.Columns[i].DataPropertyName == "ZHUANG_TAI")
     {
         index = i;
         break;
      }
    }

   ((DataGridViewComboBoxColumn)this.dtgResult.Columns[index]).DataSource = dt;
   ((DataGridViewComboBoxColumn)this.dtgResult.Columns[index]).DisplayMember = "dispValue";
   ((DataGridViewComboBoxColumn)this.dtgResult.Columns[index]).ValueMember = "memValue";
}
private DataTable getTest()
{
        DataTable dt = new DataTable();
                dt.Columns.Add("dispValue");
                dt.Columns.Add("memValue");

                DataRow oRow = null;
                oRow = dt.NewRow();
                oRow["dispValue"] = "正常";
                oRow["memValue"] = "0";
                dt.Rows.Add(oRow);

                oRow = dt.NewRow();
                oRow["dispValue"] = "停用";
                oRow["memValue"] = "1";
                dt.Rows.Add(oRow);

                oRow = dt.NewRow();
                oRow["dispValue"] = "废弃";
                oRow["memValue"] = "2";
                dt.Rows.Add(oRow);
}
需要说明的地方:
1、 dtgResult是DataGridView控件,在设计阶段已经绑定好了数据源
2、 “ZHUANG_TAI”列在设计时指定为DataGridViewComboBoxColumn类型
3、 “ZHUANG_TAI”是DataGridView数据源里的字段,在指定列的DataSource、DisplayMember、ValueMember属性时必须使用索引,而不能通过this.dtgResult.Columns[“ZHUANG_TAI”]这种方法赋值,否则会“未将对象引用设置到对象的实例”的错误,怀疑是个BUG
4、 dao.getTest():就取得值的函数,如果是从数据库取值,是保证:字段“ZHUANG_TAI”的类型和“MEMVALUE”的类型一致,或是通过类似如下的代码获取:
public DataTable getTest()
        {
            DataTable dataDic = new DataTable();
            dataDic.Columns.Add("DISPVALUE");
            dataDic.Columns.Add("MEMVALUE");
            this.oracleSelectCommand.CommandText = "Select DISPVALUE,MEMVALUE from DISPCOM";
            this.Fill(dataDic);
            return dataDic;
        }
    否则会出现表中值无法绑定上情况

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值