我试图在DGV上设置一个列作为组合框。我已将所有列添加到设计器的gridview中,因此剩下的就是将它们绑定到数据集。
“状态”列的数据类型为varchar。
但是我在运行时仍然收到一条非常无用的错误消息。我做错了吗?
DataGridViewComboBox值无效。
设置dgv的数据源时会发生上述错误。
dataGridView1.DataSource = JoblistDataSet.Tables["Joblist"];
DataGridViewComboBoxColumn Column = (DataGridViewComboBoxColumn)dataGridView1.Columns["Status"];
Column.DataPropertyName = "Status";
DataGridViewComboBoxCell cbCell = (DataGridViewComboBoxCell)dataGridView1.Rows[0].Cells["Status"];
cbCell.Items.Add("New");
cbCell.Items.Add("Hold");
cbCell.Items.Add("Remove");
dataGridView1.DataSource = JoblistDataSet.Tables["Joblist"];
答案 0 :(得分:1)
我认为问题在于您为行索引0而不是DataGridViewComboBoxCell.Items填充DataGridViewComboBoxColumn.Items,这适用于所有行(希望您注意到Cell
vs Column
)。
使用类似的东西
var statusColumn = (DataGridViewComboBoxColumn)dataGridView1.Columns["Status"];
statusColumn.DataPropertyName = "Status";
statusColumn.Items.Add("New");
statusColumn.Items.Add("Hold");
statusColumn.Items.Add("Remove");
// ...