判断 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!");
        }