从 BindingList 中删除最后一条记录选择最后一行导致 DataGridView 滚动

Posted

技术标签:

【中文标题】从 BindingList 中删除最后一条记录选择最后一行导致 DataGridView 滚动【英文标题】:Removing Last Record from BindingList Selects Last Row Causing DataGridView to Scroll 【发布时间】:2011-03-18 16:06:13 【问题描述】:

我在表单上有一个 DataGridView,当我收到新数据时,我将记录插入到绑定到 DataGridView 的 BindingList 的开头。当有足够的记录让垂直滚动条出现时,它会停留在列表的顶部。所以我总是在列表的顶部看到最新的记录。到目前为止,这项工作正常。

但是,当我添加代码以删除列表中的最后一条记录时,当它变得太长时,会自动选择列表中的最后一条记录,导致滚动条一直“滚动”到列表中的最后一条记录DataGridView 的底部。我什至在调用 RemoveAt 之前和之后添加了对 ClearSelection() 的调用,但它仍然滚动到底部。

如何防止这种行为?

【问题讨论】:

【参考方案1】:

在删除记录之前,您始终可以获取所选 DataGridViewRow 的索引或其他此类标识符。

在 bindingSource Changed 事件中,您可以解析数据并设置正确的行。

要设置第一个显示的 DataGridViewRow,请使用:

DataGridView1.FirstDisplayedScrollingRowIndex;

要选择相同的 DataGridViewRow,请使用:

DataGridView1.Rows[DataGridView1.FirstDisplayedScrollingRowIndex].Selected = true;

记得进行错误检查以确保索引值不是 -1(未选择)。

【讨论】:

以上是关于从 BindingList 中删除最后一条记录选择最后一行导致 DataGridView 滚动的主要内容,如果未能解决你的问题,请参考以下文章

从所有客户中选择 Rails 中的最后一条记录

如何从BindingList中删除哪些项目[重复]

MySQL:在表中选择第一条记录,最后一条记录和 200 条均匀间隔的记录

如何在 InfluxDB 中选择最后一条记录

使用 Eloquent 选择具有值的最后一条记录

sql查询获取已删除记录