以下代码段(问题在于:http://www.vbdotnetforums.com/winforms-grids/10038-fill-datagridview-combobox-column.html)用于在未绑定模式下填充数据网格视图中的组合框单元格:
Dim dgvcc As DataGridViewComboBoxCell
dgvcc = DataGridView1.Rows(2).Cells(0)
dgvcc.Items.Add("comboitem1")
dgvcc.Items.Add("comboitem2")
我正在尝试做同样的事情,但我不禁注意到,施法操作无效,这是VB给我的确切错误。
我稍微调整了一下代码并尝试了但仍然得到了相同的转换错误:
Dim dgvcc As Windows.Forms.DataGridViewComboBoxCell
dgvcc = Window.DataGridView1.Rows(2).Cells(0)
dgvcc.Items.Add("comboitem1")
dgvcc.Items.Add("comboitem2")
Window 是DataGridView1对象所在表单的名称。
任何人都可以告诉我一个简单的方法来在未绑定模式下填充数据网格中的组合框。你也可以告诉我为什么它不起作用,它确实对其他人有效?
答案 0 :(得分:2)
您正在使用GridViewComboBoxCell,而是使用GridViewComboBoxColumn并参考下面给出的代码片段,这样可以正常工作
Dim cbState As DataGridViewComboBoxColumn
cbState = DataGridView1.Columns("cbCol1")
cbState.Items.Add("Karnataka")
cbState.Items.Add("Andhra Pradesh")
以上代码将为DataGridview提供如下结果。
编辑:
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
Dim cbState As DataGridViewComboBoxColumn
cbState = DataGridView1.Columns("cbCol1")
cbState.Items.Insert(0, "Karnataka")
cbState.Items.Add("Andhra Pradesh")
End Sub
Private Sub DataGridView1_CellFormatting(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellFormattingEventArgs) Handles DataGridView1.CellFormatting
If e.ColumnIndex = 0 Then
e.Value = "Karnataka"
End If
End Sub