几个月前我在网上找到了这段代码。它非常适合创建 datagridview 列。我从未使用它来创建组合框列。现在我需要这样做并且无法弄清楚如何为列分配值。而且,我找不到我第一次找到这段代码的地方。我现在可以找到它的片段,但没有完整的。
创建 textboxcolumn 并创建包含值的 dgv 行很容易。但是,我不知道如何创建一个组合框列。顺便说一句,在这种情况下,列可以对每一行使用相同的组合框值。
这是我的代码:
我创建了一个数据表来保存要绑定到 dgv 的数据:
Dim dt As New DataTable("Grid")
Dim dr As DataRow
dtSetupColumns(dt)
Public Sub dtSetupColumns(ByRef dt As DataTable)
dt.Columns.Add("name_l", GetType(String))
dt.Columns.Add("name_f", GetType(String))
dt.Columns.Add("state", GetType(String))
End Sub
为数据表赋值:
dr = dt.NewRow()
dr("name_l") = ' from query table
dt.Rows.Add(dr)
创建 DataGridView 列:
dgvCreateColumns(dgv)
Public Sub dgvCreateColumns(ByRef inDataGridView As DataGridView)
With inDataGridView.Columns
.Add(dgvCreateColumn(ColumnStyle.TextBoxColumn, String.Empty, "Last Name", "name_l", 80, DataGridViewContentAlignment.MiddleLeft))
.Add(dgvCreateColumn(ColumnStyle.TextBoxColumn, String.Empty, "First Name", "name_f", 80, DataGridViewContentAlignment.MiddleLeft))
.Add(dgvCreateColumn(ColumnStyle.ComboBoxColumn, String.Empty, "State", "state", 80, DataGridViewContentAlignment.MiddleLeft))
End With
End Sub
Public Shared Function dgvCreateColumn(ByVal ColumnType As ColumnStyle, ByVal format As String, ByVal headerText As String, ByVal dataPropertyName As String, ByVal width As Integer, ByVal alignment As DataGridViewContentAlignment, Optional ByVal bMakeVisible As Boolean = True, Optional ByVal inReadOnly As Boolean = False) As DataGridViewColumn
Dim dgvC As DataGridViewColumn = Nothing
Select Case ColumnType
Case ColumnStyle.ButtonColumn
dgvC = New DataGridViewButtonColumn
Case ColumnStyle.CheckBoxColumn
dgvC = New DataGridViewCheckBoxColumn
Case ColumnStyle.ComboBoxColumn
dgvC = New DataGridViewComboBoxColumn
Case ColumnStyle.ImageColumn
dgvC = New DataGridViewImageColumn
Case ColumnStyle.LinkColumn
dgvC = New DataGridViewLinkColumn
Case ColumnStyle.TextBoxColumn
dgvC = New DataGridViewTextBoxColumn
End Select
With dgvC
.DataPropertyName = dataPropertyName
.DefaultCellStyle.Alignment = alignment
.DefaultCellStyle.Format = format
If ColumnType = ColumnStyle.ButtonColumn Then
'.colum()
End If
.HeaderText = headerText
.Name = headerText
.ReadOnly = inReadOnly
If width = 0 Then
.Visible = False
Else
.Width = width
If bMakeVisible = False Then
.Visible = False
Else
.Visible = True
End If
End If
End With
Return dgvC
End Function