对DataGridView某行进行修改之后,保证光标显示仍在选中行上?

本文介绍在C#中使用DataGridView控件时如何确保光标显示在已修改的行上,包括获取选中行索引、设置滚动条位置及强制显示选中行的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:
       对DataGridView某行进行修改之后,保证光标显示仍在选中行上?
现实问题:
      当前的开发中遇到Datagridview的操作,在对Datagridview中单选行进行操作之后,要回到


Datagridview显示界面,但是显示选中行总是在第一行,这样的话,当数据库中数据行太多的时候,显示太多,选择行也许就修改后客户就找不到自己修改的那一行了


解决方案:


搜索资料:1.得到选中行的行号
                int i = DataGridView1.CurrentCell.RowIndex  //当前行号
                int j = DataGridView1.CurrentCell.ColumnIndex //当前列号


             2.指定DataGridView的滚动框位置


                DataGridView1.FirstDisplayedScrollingRowIndex = 0


                DataGridView1.FirstDisplayedScrollingColumnIndex = 0


             为了解决这个问题,我们可以将Datagridview的滚动块位置设置为修改行的那个位置。这样在Datagridview显示的第一行就是客户操作行了。
具体做法:在选中要修改行的时候,即可获取选中行的Index,方法 
(int i = DataGridView1.CurrentCell.RowIndex)
在修改完成后,指定滚动块的位置(DataGridView1.FirstDisplayedScrollingRowIndex = i))


注:这几天国庆放假中,等上班了再验证下,是否可行。


搜索资料:3.在还没有去实现并继续搜索资料中发现,有人提出一个新问题,那就是:在如上操作后显示


的第一行就是我们开始选中的那一行,但是之后 取 CurrentRows 时候会出现和selected rows不同的行。
提出的解决方案为:DataGridView1.Rows(i).Selected = True 设置能保证选中行;
                        DataGridView1.CurrentCell = DataGridView1.Rows(i).Cells(0) 并且滚动条也会自动的滚动。


      DataGridView1.Rows(0).Selected = False
      DataGridView1.Rows(i).Selected = True
      DataGridView1.FirstDisplayedScrollingRowIndex = i
      还有人提到解决方法,但是没去实践,所以不知道具体会是怎么样,所以先记录下来
     (dataGridView1[columnIndex, rowIndex].Selected = true;
        dataGridView1.CurrentCell = dataGridView1[columnIndex, rowIndex]; // 强制


      显示)


今天上班,经过调试,发现这几位仁兄把问题都提到了


总结下:


           int i = DataGridView1.CurrentCell.RowIndex  //得到该行的索引号


       dataGridView1[columnIndex, i].Selected = true   //光标移至该行


           DataGridView1.FirstDisplayedScrollingRowIndex = i   //将滑块移动到该行


介于,如果在上面操作之后仍要对表格进行操作,比如通过DataGridView1.CurrentCell 查找该行的数据列,那么我们必须做以下操作,因为这个时候真出现了以上那个问题 CurrentRows 时候会出现和selected rows不同的行


       dataGridView1.CurrentCell = dataGridView1[columnIndex, i]; // 强制显示该行




           int i = DataGridView1.CurrentCell.RowIndex  //得到该行的索引号


           dataGridView1.Rows[0].Selected = false   //关闭0行的光标显示




           dataGridView1.CurrentCell = dataGridView1[columnIndex, i]; // 强制将光标指向i行  


           dataGridView1.Rows[i].Selected = true   //光标显示至i行


                DataGridView1.FirstDisplayedScrollingRowIndex = i   //将滑块移动到该行


注:columnIndex为任一列序号,如(0,1,2,3……)但要确保这一列是显示的不是隐藏的列,要不然会报错。。。。。


通过以上语句,将光标强制转到该行,(大概意思应该是这样吧)这样就可以准确的取到该行的数据了。


经以上操作,我们看到显示行确实是我们要的那一行,但是第一行也有显示了,这样就有两行是选择行,所以我就添加了一下第二行代码,关闭了第一行的显示;之后呢?当我们仔细看前面的光标指向,就是行最前面的箭头还是指向第一行的,所以我们还得做强制转移光标的行为,如第三行代码。 




再次更新,滑块的初始位置我们也可以获取到,要保证显示位置一致的话,我们可以将原来滑块位置赋给当前位置就好了


添加一行代码


                int FirstRowIndex = DataGridView1.FirstDisplayedScrollingRowIndex//得到该行的索引号


后面确定滑块位置的时候,把这个值赋给他就好了


           DataGridView1.FirstDisplayedScrollingRowIndex = FirstRowIndex  ;


          




再次更正:


           


咳,该死的C#什么都封装好了,原以为是这样,原来不需要最后移动滑块,开始光标的定位已经将滑块移动到要显示的行了,第一行就是我们要显示的行了。所以,如果只是添加或者删除,就不需要最后一行代码了。


但是选中修改行后,要不让他滑动到第一行的话就用下面的方法吧:


找到初始滑块位置,在最后再赋还给滑块就好了,那么原来数据行显示在哪,更新后还是显示在那。。。




再一次完善:


     添加,修改,删除时用的方法各不相同,考虑到各种情况的发生。


            switch(条件)
            {
                case Add:
                    if (dgv.RowCount > 0)
                    {
                        dgv.Rows[0].Selected = false;
                        dgv.CurrentCell = dgv[k, dgv.RowCount - 1];
                        dgv.Rows[dgv.RowCount - 1].Selected = true;
                        //dgv.FirstDisplayedScrollingRowIndex = dgv.RowCount - 1;
                    }
                    break;
                case Update:
                    {
                        dgv.Rows[0].Selected = false;
                        dgv.CurrentCell = dgv[k, RowIndex];
                        dgv.Rows[RowIndex].Selected = true;
                        dgv.FirstDisplayedScrollingRowIndex = FirstRowIndex;
                    }
                    break;
                case Delete:
                    if (dgv.RowCount > 0)
                    {
                        if (RowIndex > 0 && (RowIndex - 1) < dgv.RowCount)
                        {
                            dgv.Rows[0].Selected = false;
                            dgv.CurrentCell = dgv[k, RowIndex - 1];
                            dgv.Rows[RowIndex - 1].Selected = true;
                        }//dgv.FirstDisplayedScrollingRowIndex = RowIndex - 1;
                        else if (RowIndex <= 0)
                        {
                            dgv.Rows[0].Selected = true;
                        }
                        else
                        {
                            dgv.Rows[0].Selected = false;
                            dgv.CurrentCell = dgv[k, dgv.RowCount - 1];
                            dgv.Rows[dgv.RowCount - 1].Selected = true;
                        }
                    }
                    break;
                default:
                    break;
            }





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)
<think>嗯,用户的问题是关于如何在C# WinForms的DataGridView中以编程方式中特定行。首先,我需要回忆一下DataGridView的常用属性和方法。记得DataGridView有Rows集合,每个行可能有Selected属性。或者是否应该使用CurrentCell属性来设置当前中的单元格,从而间接中行?可能需要确认一下。 然后,用户提到要“中某一行”,可能指的是中整行,而不仅仅是某个单元格。这时候需要设置SelectionMode属性,确保它是FullRowSelect,这样中单元格时才会整行高亮。如果SelectionMode是其他值,比如CellSelect,那么即使设置Selected属性为True,可能也不会显示整行中。 接下来,具体的代码步骤。首先,可能需要遍历DataGridView的Rows集合,找到目标行的索引。例如,根据某个条件(比如某一列的值)来定位行。找到行后,设置其Selected属性为True。同时,可能需要调用ClearSelection方法先取消所有已中的行,避免多。或者,如果允许多,可以保留其他中的行。 另外,可能还需要将当前单元格设置为该行的某个单元格,以确保视图滚动到该行。这可以通过设置CurrentCell属性来实现。例如,dataGridView1.CurrentCell = dataGridView1.Rows[rowIndex].Cells[0]; 这样用户可以看到中的行出现在可视区域。 还要考虑异常处理,比如行索引是否有效,是否存在符合条件的行,否则可能会抛出异常。因此,在代码中需要添加检查,确保行索引在有效范围内。 参考用户提供的引用内容,引用[2]提到DataGridView可以显示非绑定和绑定的数据,这可能影响到如何访问行数据。如果数据是绑定的,可能需要通过DataBoundItem或其他方式获取行对应的数据对象,再进行条件匹配。不过用户的问题更多是关于中行,而不是数据源的处理。 另外,用户提供的引用[3]中提到了DataGridViewLinkColumn和组合框列,可能涉及到列的特定类型,但当前问题主要关注行择,可能不需要深入处理特定列类型,除非中行的条件涉及这些列的值。 总结步骤应该是:1. 确保SelectionMode为FullRowSelect;2. 找到目标行的索引;3. 清除现有择(可);4. 设置行的Selected属性;5. 设置CurrentCell以便滚动到该行。同时,注意异常处理和性能问题,特别是在数据量大时,遍历可能需要优化。 可能需要提供两种方法:一种是通过行索引直接择,另一种是通过条件查找行。例如,用户可能需要根据某个字段的值,如ID,来找到对应的行。这时候需要遍历Rows集合,检查每行的单元格值是否符合条件,找到对应的行索引。 最后,代码示例应该清晰,展示如何实现这些步骤。比如,使用dataGridView1.ClearSelection(),然后设置dataGridView1.Rows[i].Selected = true,并设置CurrentCell。同时提醒用户设置SelectionMode,否则可能看不到整行中效果。</think>在C# WinForms中通过编程方式DataGridView特定行的步骤如下: ### 一、核心实现方法 1. **设置择模式**(必须步骤) ```csharp dataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect; // 确保整行高亮显示[^2] ``` 2. **通过索引择行** ```csharp // 中第3行(索引从0开始) int targetRowIndex = 2; dataGridView1.ClearSelection(); dataGridView1.Rows[targetRowIndex].Selected = true; dataGridView1.CurrentCell = dataGridView1.Rows[targetRowIndex].Cells[0]; // 确保滚动到可视区域 ``` 3. **通过条件查找行**(示例根据ID字段) ```csharp int searchId = 100; foreach (DataGridViewRow row in dataGridView1.Rows) { if (row.Cells["ID"].Value?.ToString() == searchId.ToString()) { dataGridView1.ClearSelection(); row.Selected = true; dataGridView1.CurrentCell = row.Cells[0]; break; } } ``` ### 二、高级技巧 1. **多控制**: ```csharp dataGridView1.MultiSelect = true; // 允许多行dataGridView1.Rows[1].Selected = true; dataGridView1.Rows[3].Selected = true; ``` 2. **数据绑定场景**: ```csharp // 当使用DataTable作为数据源时 var row = ((DataTable)dataGridView1.DataSource).Select($"ID = {searchId}").FirstOrDefault(); if (row != null) { int index = ((DataTable)dataGridView1.DataSource).Rows.IndexOf(row); dataGridView1.Rows[index].Selected = true; } ``` ### 三、注意事项 1. 确保在`DataBindingComplete`事件之后操作行择,避免数据未加载完成时出现空引用异常 2. 操作虚拟模式数据源时需通过`RowIndex`映射到实际数据项 3. 建议在UI线程中执行择操作,防止跨线程访问控件异常
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值