关于VB.NET Datagridview 新加行的问题,哪位大佬知道?

有个问题比较苦恼,通过 Datagridview 操作数据库,数据行数超过一页的时候,新增行总是在页面最底部,这样很不习惯,各位大大,有没有办法可以把这个新增行调整到屏幕中间一些呢?

你说的新增行是在datagridview上操作增加的那一行吗?

是的,就在表格最下面,没有数据的那一行

不如新增一個新增界面,想在哪裡就在哪裡

不方便啊,要增加新数据时,需要和上文的数据相比较。
设置新增界面,操作比较不合适啊

我一般都是用Datagridview 显示, 编辑还是在textbox里

需要类似EXCEL那样子的数据输入界面,所以想用资源代下载网Datagridview 一起解决了界面问题

基本上都做好了,就是感觉那个输入数据的一行总是在最下面,感觉别扭,眼睛总往下瞄,不舒服

那你可以判斷的啊,要點擊一個按鈕新增,然後只是顯示最後幾行數據,不是在中間了嗎

那要先判断本页显示多少条数据?然后显示的行数如果超过一定数量,使新增数据行位于屏幕中下部分时自动减少显示的行数?但是这样子我要查看显示之外的数据要重新再加载一次数据源了,才能查看到其他未显示的数据?
我是通过 BindingNavigator 作为 datagridview 的数据源的

插入空行,这个是可以实现在鼠标点击位置新增空行.获取鼠标位置插入空行.

其实,再最下方新增行是最正常的,或者单独做一个窗体(仿gridview),直接在中间加是没问题的,增加时获取一下当前显示的gridview中的上下限,在计算下中间的数据时行号。这个会造成视觉混淆

多加一些空行,更新时不要这些空行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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)
你可以通过以下步骤实现 DataGridView 中拖拽一排序: 1. 设置 DataGridView 的 AllowUserToOrderColumns 属性为 True,允许用户拖拽列头进排序。 2. 设置 DataGridView 的 AllowUserToResizeRows 属性为 False,禁止用户调整高度。 3. 添加 DataGridView 的 MouseDown、MouseMove 和 MouseUp 事件,实现拖拽的功能。 4. 在 MouseDown 事件中,获取当前鼠标所在的索引,并将其保存到一个变量中。 5. 在 MouseMove 事件中,判断鼠标是否按下并移动,如果是,则将当前拖拽到鼠标所在的位置。 6. 在 MouseUp 事件中,获取鼠标所在的索引,并将其与之前保存的索引进比较,如果不同,则交换两的位置。 下面是一个简单的示例代码: ``` Dim draggingRow As DataGridViewRow = Nothing Private Sub DataGridView1_MouseDown(sender As Object, e As MouseEventArgs) Handles DataGridView1.MouseDown If e.Button = MouseButtons.Left Then Dim hit As DataGridView.HitTestInfo = DataGridView1.HitTest(e.X, e.Y) If hit.Type = DataGridViewHitTestType.RowHeader Then draggingRow = DataGridView1.Rows(hit.RowIndex) End If End If End Sub Private Sub DataGridView1_MouseMove(sender As Object, e As MouseEventArgs) Handles DataGridView1.MouseMove If e.Button = MouseButtons.Left And draggingRow IsNot Nothing Then Dim mouseY As Integer = DataGridView1.PointToClient(MousePosition).Y Dim targetRow As Integer = DataGridView1.HitTest(0, mouseY).RowIndex If targetRow >= 0 And targetRow <> draggingRow.Index Then DataGridView1.Rows.Remove(draggingRow) DataGridView1.Rows.Insert(targetRow, draggingRow) End If End If End Sub Private Sub DataGridView1_MouseUp(sender As Object, e As MouseEventArgs) Handles DataGridView1.MouseUp draggingRow = Nothing End Sub ``` 在这个示例代码中,我们通过鼠标的按下、移动和释放事件来实现的拖拽排序功能。当鼠标按下时,我们获取当前鼠标所在的索引,并将其保存到变量 draggingRow 中。当鼠标移动时,我们判断鼠标是否按下并移动,如果是,则将当前拖拽到鼠标所在的位置。当鼠标释放时,我们清空变量 draggingRow。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值