C# DataGridView 数据显示到最后一行后,如何使滚动条继续向下滚动。
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# DataGridView 数据显示到最后一行后,如何使滚动条继续向下滚动。相关的知识,希望对你有一定的参考价值。
DataGridView显示数据,在数据量过多时,滚动条拉到最下面时显示出新增行,然而新增行总是在最下方,所以新增信息时会不太方便。
可不可以使滚动条拉到新增行时,继续向下拉,相当于最后一行下面可以显示出一部分空白。
可以参数SQL 2000数据库中查看数据的表格,SQL2000中就可以拉到新增行时,继续向下拉滚动条。
1.当拖动滚动条至显示出最后一条时,继续向下拖动才显示空白。
显然在下方直接添加Panel不合适,而且滚动条也无法控制panel
2.自定义滚动条,我尝试着使dgv.FirstDisplayedScrollingRowIndex = dgv.rows.count - 1
但系统会计算出一个FirstDisplayedScrollingRowIndex 最大值,在超出这个值后就无线了。所以还是无法实现到最后一行时,使所有行继续向上走。
在绑定的时候绑定数据源.Reverse(),就OK啦.. 其他的帮不上你啦...
我最近也在用DataGridView追问
首先谢谢odinDii提供的思路,不过这样仅仅解决了单方面的问题,如果把新增行放到最上面,那么用户查看上一次新增的数据就比较麻烦了。
参考技术A 那就在DataGridView的下面加一个空白区域应该就可以解决你的问题了_____________________________________________________________________________
根据你说的效果用js可以实现,你将下面的代码加入页面中就可以了,可能有些细节上需要调整,如果需要再问吧
<div style="position:absolute; width:100%; height:22px;" id="divBottom"></div>
<script type="text/javascript">
var divBottom = document.getElementById("divBottom");
function divBottomLocation()
divBottom.style.top = document.documentElement.scrollTop + document.documentElement.clientHeight + "px";
//窗体滚动条事件
window.onscroll = function()
divBottomLocation();
;
divBottomLocation();
</script> 参考技术B 设置DataGridView控件的滚动条属性,在属性框里面把ScrollBars设置成Vertical就行了,共有四个属性,可根据情况选择 参考技术C 如果你向DataGridView中添加数据的时候用到循环了,你可以这样
选中你当前添加的行,滚动条自动滚动,即保持当前页面显示最新数据
dataGridView1.CurrentCell = dataGridView1.Rows[i].Cells[0];
从 DataGridView 列中获取值,最后为空行 c#
【中文标题】从 DataGridView 列中获取值,最后为空行 c#【英文标题】:Get values from a DataGridView Column, empty row at the end c# 【发布时间】:2020-05-06 10:22:56 【问题描述】:我正在使用一个允许我向 DataGridView 添加一些行的应用程序:
如您所见,最后一行是空的,这是为了允许添加更多行。 好的,当我尝试获取“Codigo”列中的所有值时出现问题:
(DB)335T1613 (DB)335T1642 (DB)335T1644最后一行是空的,所以没有值,我得到以下错误:
新的未确认行不能删除
这是我的代码,我试图在其中获取这些值:
private void buttonAccept_Click(object sender, EventArgs e)
/*if (dataGridViewTennetPaint.Rows(dataGridViewTennetPaint.Rows.Count - 1).IsNewRow)
dataGridViewTennetPaint.Rows.RemoveAt(dataGridViewTennetPaint.Rows.Count - 1);
*/
dataGridViewTennetPaint.Rows.RemoveAt(dataGridViewTennetPaint.Rows.Count - 1);
string data = string.Empty;
int indexOfYourColumn = 0;
int cont = 0;
foreach (DataGridViewRow row in dataGridViewTennetPaint.Rows)
//if (!row.Cells[indexOfYourColumn].Equals(null) || row.Cells[indexOfYourColumn] != null || row.Cells[indexOfYourColumn].Value.ToString() != "" || row.Cells[indexOfYourColumn].Value.ToString().Equals("") || row.Cells[indexOfYourColumn].Equals("") || row.Cells[indexOfYourColumn].Value.ToString() != "")
if (row.Cells[indexOfYourColumn].Value != System.DBNull.Value)
data = row.Cells[indexOfYourColumn].Value.ToString();
cont++;
System.Diagnostics.Debug.WriteLine("Data contiene ... " + data + " cont: " + cont);
【问题讨论】:
代码中的哪一行给出了错误? 如果您允许用户“添加”行,则网格AllowUserToAddRows
属性设置为true
。将此属性设置为true
,您不能删除“最后一个”新行。幸运的是,每一行都有一个名为IsNewRow
的布尔属性。因此,在 foreach
循环遍历网格的行……添加一个检查这个“新行”……if (!row.IsNewRow) ... ;
【参考方案1】:
首先,您需要从 DataGrid 中删除最后一行,因为它不再使用。
请将 CanUserAddRows 设置为 false。
CanUserAddRows="False"
使用的电池 BindingList 绑定到 DataGrid 并从 TableView 中获取所有行。
【讨论】:
以上是关于C# DataGridView 数据显示到最后一行后,如何使滚动条继续向下滚动。的主要内容,如果未能解决你的问题,请参考以下文章
C#中怎样将dataGridView中的新添加的一行数据添加到数据库中
c#中 datagridview单击选中一行数据,点修改按钮,跳转到另外一个窗体并显示数据,修改保存