繁体   English   中英

c#设置在datagridview组合框单元格中选择哪个项目

[英]c# set which item is selected in datagridview combobox cell

我有两种形式,一种是用一些行填充DataGridView ,每行有两个组合框。

我能够从这些单元格中获取值和格式化值,但是当我尝试将所有这些数据复制到下一个不同形式的DataGridView中时,我无法告诉他ComboBox哪个项目应该被标记为选中.

当我环顾四周时,我发现了这些代码行(不幸的是,它们来自 6 多年前)

dataGridView.Rows[index].Cells[3].Value = ImageFormat.Items[1];

(dataGridView.Rows[index].Cells[3] as DataGridViewComboBoxCell).Value = ImageFormat.Items[0];

DataGridViewComboBoxCell comboboxFormat = (DataGridViewComboBoxCell)(dataGridView.Rows[index].Cells[3]);

comboboxFormat.Value = ImageFormat.Items[0];

(dataGridView.Rows[index].Cells[3] as DataGridViewComboBoxCell).Value = (dataGridView.Rows[index].Cells[3] as DataGridViewComboBoxCell).Items[0];

不幸的是,这些都不起作用,而且大多数(如果不是全部)抛出“DataGridViewComboBoxCell 值无效”异常

也许值得一提的是,可能的项目是从数据库中绑定的,如下所示:

string stm = "SELECT * FROM colours";
            using var cmd = new SQLiteCommand(stm, MainWin.con);
            SQLiteDataAdapter rdr = new SQLiteDataAdapter(cmd);
            DataTable dataTableColour = new DataTable();
            rdr.Fill(dataTableColour);

            stm = "SELECT * FROM formats";
            using var cmdd = new SQLiteCommand(stm, MainWin.con);
            SQLiteDataAdapter reader = new SQLiteDataAdapter(cmdd);
            DataTable dataTableFormat = new DataTable();
            reader.Fill(dataTableFormat);

            ImageFormat.ValueMember = "id";
            ImageFormat.DisplayMember = "name";
            ImageFormat.DataSource = dataTableFormat;

            ColourImage.ValueMember = "id";
            ColourImage.DisplayMember = "name";
            ColourImage.DataSource = dataTableColour;

您的 datagridview 应该绑定到某个数据表(比如说 ImageFiles)。 ColourImage / ImageFormat组合的.DataPropertyName属性设置为组合应编辑的 [ImageFiles] 数据表中列的名称。 不要试图直接与 DGVCombo 交互; 只需与网格绑定到的数据表进行交互

在此处输入图片说明

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM