判断 DataGridView控件滚动条是否滚动到当前已加载的数据行底部,其实方法很简单,就是为DataGridView控件添加Scroll事件,然后写入以下代码就可以了,应用范围:可实现分部加载数据,以提升用户体验!

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
private void dataGridView1_Scroll( object sender, ScrollEventArgs e)
         {
             if (e.ScrollOrientation == ScrollOrientation.VerticalScroll)
             {
                
                 if (e.NewValue + dataGridView1.DisplayedRowCount( false ) == dataGridView1.Rows.Count)
                 {
                 
                     MessageBox.Show( string .Format( "NewValue:{0}--OldValue:{1}--DisplayedRowCount:{2}" , e.NewValue, e.OldValue,dataGridView1.DisplayedRowCount( false )));
                     MessageBox.Show( "到底了,可以加载新数据了!" );
                     //这里面写加载数据的相关操作逻辑
                 }
             }
         }

如果你的项目中有很多的 DataGridView控件都需要应用该事件,那么以上的做法就显示有所繁琐,因为每个DataGridView控件都需要添 加Scroll事件,且都需要写上面的判断代码,为了解决这个问题,如下我采用了为DataGridView控件扩展了一个 RegistScrollToEndEvent方法,该方法的作用就是当你需要用到滚动到末尾时需触发的事件,那么你只需要提前将事件以参数的形式注入到 指定的DataGridView控件中:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
/// <summary>
         /// 注册滚动条滚功到末尾时的处理事件
         /// </summary>
         /// <param name="grid"></param>
         /// <param name="onScrollToEnd"></param>
         public static void RegistScrollToEndEvent( this DataGridView grid, EventHandler onScrollToEnd)
         {
             grid.Scroll += new ScrollEventHandler((sender, e) =>
             {
                 if (e.ScrollOrientation == ScrollOrientation.VerticalScroll)
                 {
                     if (e.NewValue + grid.DisplayedRowCount( false ) == grid.Rows.Count)
                     {
                         if (onScrollToEnd != null )
                         {
                             onScrollToEnd(grid, null );
                         }
                     }
                 }
             });
         }

用法很简单:

?
1
2
3
4
5
6
dataGridView1.RegistScrollToEndEvent(dataGrid_OnScrollToEnd);
 
void dataGrid_OnScrollToEnd( object sender, EventArgs e)
         {
             MessageBox.Show( "load data!" );
         }