yingnian_00 2014-11-26 13:22 采纳率: 0%
浏览 3256

C# DataGridView绑定数据源后ComboBoxCell的Items下拉列表为什么会被清空

我有一列DataGridViewComboBoxColumn,每个cell的下拉列表内容不同,于是循环

for(int i = 0, i < max, i++)  
{  
    dgv.Rows.Add(new DataGridViewRow());  
    DataGridViewComboBoxCell cell = dgv.Rows[i].Cells[1] as DataGridViewComboBoxCell; //第二列  
    //comboCol.Items.AddRange(list[i].toArray()); //comboCol 第二列名  
    cell.Items.AddRange(list[i].toArray());  
} 

然后给DataGridView绑定数据源

dgv.DataSource = new BindingList<object>(objList);  
dgv.Columns[0].DataPropertyName = "col1";  
dgv.Columns[1].DataPropertyName = "col2";  

在绑定这三行代码的前后分别检查第二列某行cell的Items.Count发现绑定前有长度,但是绑定后长度为0,也就是给这些cell添加的下拉项都清空了!绑定后再次添加项也没用,还是会清空。
另外在循环里如果用注释掉的那行代码,也就是给整列添加项,那就没有问题,但是就不能满足我每个cell下拉内容不同这个需求。
又试了试发现如果不绑定,直接给cell赋值,cell.Value = "v1"这样的话也不会有问题,但我需要绑定。
实在没有头绪,不知道怎么回事。

  • 写回答

1条回答

  • a276538015 2014-12-02 03:05
    关注

    由于控件刷新后,清空了数据。

    评论

报告相同问题?

悬赏问题

  • ¥15 outlook无法配置成功
  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题