VB.NET —DataGridView控件操作

一、基本操作

`DataGridView` 控件是 VB.NET 中用于显示和编辑数据的强大控件,常用于数据表格的展示和管理。### 1. **基本设置**

首先,你需要将 `DataGridView` 控件添加到你的窗体上。这可以通过设计器完成,也可以通过代码动态添加。

### 2. **绑定数据源**

`DataGridView` 控件可以绑定到多种数据源,例如 `DataTable`、`BindingList`、`List` 等。下面是将 `DataTable` 绑定到 `DataGridView` 的示例:

```vb
' 创建 DataTable
Dim dataTable As New DataTable()
dataTable.Columns.Add("ID", GetType(Integer))
dataTable.Columns.Add("Name", GetType(String))
dataTable.Columns.Add("Age", GetType(Integer))

' 添加数据行
dataTable.Rows.Add(1, "Alice", 30)
dataTable.Rows.Add(2, "Bob", 25)

' 绑定到 DataGridView
DataGridView1.DataSource = dataTable
```

### 3. **添加列**

你可以通过代码动态添加列到 `DataGridView`:

```vb
' 添加列
DataGridView1.Columns.Add("Column1", "Name")
DataGridView1.Columns.Add("Column2", "Age")

' 添加行
DataGridView1.Rows.Add("Alice", 30)
DataGridView1.Rows.Add("Bob", 25)
```

### 4. **自定义列**

你可以自定义列的类型和显示方式,例如使用 `DataGridViewCheckBoxColumn` 或 `DataGridViewComboBoxColumn`:

```vb
' 添加 CheckBox 列
Dim checkBoxColumn As New DataGridViewCheckBoxColumn()
checkBoxColumn.Name = "IsActive"
checkBoxColumn.HeaderText = "Active"
DataGridView1.Columns.Add(checkBoxColumn)

' 添加 ComboBox 列
Dim comboBoxColumn As New DataGridViewComboBoxColumn()
comboBoxColumn.Name = "Category"
comboBoxColumn.HeaderText = "Category"
comboBoxColumn.Items.Add("Category1")
comboBoxColumn.Items.Add("Category2")
DataGridView1.Columns.Add(comboBoxColumn)
```

### 5. **编辑和删除数据**

`DataGridView` 支持编辑和删除操作。默认情况下,用户可以直接在控件中进行编辑。你可以通过代码删除选中的行:

```vb
' 删除选中的行
For Each row As DataGridViewRow In DataGridView1.SelectedRows
    DataGridView1.Rows.Remove(row)
Next
```

### 6. **处理事件**

你可以处理 `DataGridView` 的各种事件,例如 `CellValueChanged`、`RowEnter`、`CellClick` 等:

```vb
Private Sub DataGridView1_CellValueChanged(sender As Object, e As DataGridViewCellEventArgs) Handles DataGridView1.CellValueChanged
    MessageBox.Show("Cell value changed!")
End Sub

Private Sub DataGridView1_RowEnter(sender As Object, e As DataGridViewCellEventArgs) Handles DataGridView1.RowEnter
    MessageBox.Show("Row entered: " & e.RowIndex.ToString())
End Sub
```

### 7. **设置外观**

你可以通过代码或设计器设置 `DataGridView` 的外观,例如调整列宽、设置背景色等:

```vb
' 设置列宽
DataGridView1.Columns(0).Width = 100

' 设置行高
DataGridView1.RowTemplate.Height = 30

' 设置背景色
DataGridView1.BackgroundColor = Color.LightGray
```

### 8. **排序和筛选**

`DataGridView` 支持排序和筛选。你可以通过设置 `DataGridView` 的 `Sort` 方法来进行排序:

```vb
' 排序
DataGridView1.Sort(DataGridView1.Columns("Name"), System.ComponentModel.ListSortDirection.Ascending)
```

### 9. **分页**

`DataGridView` 默认不支持分页,但你可以结合 `BindingSource` 和 `DataTable` 来实现分页功能。分页通常涉及到数据的分段加载和显示,你需要手动管理页码和数据的切换

二、常用触发事件

### 1. **`CellClick`**

当用户单击 `DataGridView` 控件中的单元格时发生。

```vb
Private Sub DataGridView1_CellClick(sender As Object, e As DataGridViewCellEventArgs) Handles DataGridView1.CellClick
    MessageBox.Show("Cell clicked at row " & e.RowIndex & ", column " & e.ColumnIndex)
End Sub
```

### 2. **`CellValueChanged`**

当单元格的值发生更改时发生。需要启用 `DataGridView` 的 `CellValueChanged` 事件,并在 `CellValueChanged` 事件中处理。

```vb
Private Sub DataGridView1_CellValueChanged(sender As Object, e As DataGridViewCellEventArgs) Handles DataGridView1.CellValueChanged
    MessageBox.Show("Cell value changed at row " & e.RowIndex & ", column " & e.ColumnIndex)
End Sub
```

### 3. **`RowEnter`**

当用户进入某一行时触发。

```vb
Private Sub DataGridView1_RowEnter(sender As Object, e As DataGridViewCellEventArgs) Handles DataGridView1.RowEnter
    MessageBox.Show("Entered row " & e.RowIndex)
End Sub
```

### 4. **`RowLeave`**

当用户离开某一行时触发。

```vb
Private Sub DataGridView1_RowLeave(sender As Object, e As DataGridViewCellEventArgs) Handles DataGridView1.RowLeave
    MessageBox.Show("Left row " & e.RowIndex)
End Sub
```

### 5. **`CellFormatting`**

在单元格绘制之前对其进行格式化。这对于修改单元格的显示样式很有用。

```vb
Private Sub DataGridView1_CellFormatting(sender As Object, e As DataGridViewCellFormattingEventArgs) Handles DataGridView1.CellFormatting
    If e.ColumnIndex = 1 AndAlso e.Value IsNot Nothing Then
        Dim value As Integer = Convert.ToInt32(e.Value)
        If value > 50 Then
            e.CellStyle.BackColor = Color.Yellow
        End If
    End If
End Sub
```

### 6. **`CellValidating`**

在单元格编辑完成并且失去焦点之前触发,用于验证输入。

```vb
Private Sub DataGridView1_CellValidating(sender As Object, e As DataGridViewCellValidatingEventArgs) Handles DataGridView1.CellValidating
    If e.ColumnIndex = 0 AndAlso String.IsNullOrWhiteSpace(e.FormattedValue.ToString()) Then
        DataGridView1.Rows(e.RowIndex).ErrorText = "This cell cannot be empty."
        e.Cancel = True
    End If
End Sub
```

### 7. **`CellEndEdit`**

当用户完成对单元格的编辑时触发。

```vb
Private Sub DataGridView1_CellEndEdit(sender As Object, e As DataGridViewCellEventArgs) Handles DataGridView1.CellEndEdit
    MessageBox.Show("Finished editing cell at row " & e.RowIndex & ", column " & e.ColumnIndex)
End Sub
```

### 8. **`UserAddedRow`**

当用户添加新行时触发。这通常在启用用户添加行时发生。

```vb
Private Sub DataGridView1_UserAddedRow(sender As Object, e As DataGridViewRowEventArgs) Handles DataGridView1.UserAddedRow
    MessageBox.Show("A new row was added.")
End Sub
```

### 9. **`RowsRemoved`**

当行被删除时触发。

```vb
Private Sub DataGridView1_RowsRemoved(sender As Object, e As DataGridViewRowsRemovedEventArgs) Handles DataGridView1.RowsRemoved
    MessageBox.Show("Rows removed: " & e.RowCount)
End Sub
```

### 10. **`DataError`**

当 `DataGridView` 控件在数据绑定时遇到错误时触发。

```vb
Private Sub DataGridView1_DataError(sender As Object, e As DataGridViewDataErrorEventArgs) Handles DataGridView1.DataError
    MessageBox.Show("Data error: " & e.Exception.Message)
End Sub
```

### 11. **`CellDoubleClick`**

当用户双击单元格时触发。

```vb
Private Sub DataGridView1_CellDoubleClick(sender As Object, e As DataGridViewCellEventArgs) Handles DataGridView1.CellDoubleClick
    MessageBox.Show("Cell double-clicked at row " & e.RowIndex & ", column " & e.ColumnIndex)
End Sub
```

### 12. **`ColumnHeaderMouseClick`**

当用户点击列标题时触发。

```vb
Private Sub DataGridView1_ColumnHeaderMouseClick(sender As Object, e As DataGridViewCellMouseEventArgs) Handles DataGridView1.ColumnHeaderMouseClick
    MessageBox.Show("Column header clicked at column " & e.ColumnIndex)
End Sub
```

vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 DataGridView控件用法合集(二) 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView中输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字列换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView中显示选择框CheckBox 46. DataGridView中显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView中显示按钮 49. DataGridView中显示链接 50. DataGridView中显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑中单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一列中显示相应图片 57. DataGridView中显示进度条(ProgressBar) 58. DataGridView中添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridView中Enter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

XIAO MAI

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值