ASP.NET MVC3 利用滚动条加载数据

  滚动条加载数据是当前比较流行的分页方式。

  操作方式:根据滚动条的当前位置来加载更多的数据。

  主要有2种形式。

  1:边滚动边加载数据,一开始把容器的高度计算好,当滚动条移动到空白位置时加载更多的数据。类似于 http://qing.blog.sina.com.cn/tag/%E6%97%B6%E5%B0%9A

  2:滚动到底部加载数据,当滚动条移动到底部时加载更多的数据。类似于“百度图片”的效果。

  它的优点:可以利用滚轮进行分页,而不需要点击按钮,方便用户快速地浏览完整的信息,不用经常点击分页按钮。在手机端的效果特别明显。

  它的缺点:对于想快速查看某些数据时不是很方便,假如用户想查看靠后的数据时,需要先加载前面的所有数据才能找到想要的数据。

  

  实现方式:利用 ASP.NET MVC + Jquery 框架比较容易实现这种效果(由于本人最近都没有使用 WEBFORM ,比较生疏,就不拿出来献丑)

  ASP.NET MVC3 利用滚动条加载数据

  已滚动到底部加载数据为例子说明,这个实现起来比较容易。  

  html 部分,div : Container 控制滚动条的容器,div : DataList 加载数据的容器。 Container 需要 加上 height: 420px;overflow-y: auto; 样式

  JS 部分,主要是针对 Container容器的滚动条进行操作,判断是否去掉底部。
可使用 $("#Container")[0].scrollTop + $("#Container").height() >= $("#Container")[0].scrollHeight - 10,关于这几个属性的详细说明请自行在网络上查看,
需要说明的是  -10 主要是为了兼容chrome 浏览器,不同浏览器对滚动条的属性解析会不同,如果列表样式过于复杂,需要反复调试。    

 1 function Add_Data() {

 2     var scrollTop = $("#Container")[0].scrollTop;

 3     if (!complete && loaded) {

 4         if (scrollTop + $("#Container").height() >= $("#Container")[0].scrollHeight) {

 5             getData();

 6         }

 7 

 8     }

 9 }

10 

11 function getData() {

12     loaded = false;

13     $.ajax({

14         url: '@Url.Action("MainListPanel", "Home")',

15         type: 'POST',

16         data: {

17             createTime: maxTime,

18             skipCount: skipCount,

19             takeCount: takeCount

20         },

21         dataType: 'html',

22         timeout: 10000,

23         error: function () { alert('Error loading'); },

24         beforeSend: function () {

25             //$("#DataList").append("<img class='loading' src='../../Content/ajaxloading.gif' />");

26             $("#box").show();

27         },

28         success: function (result) {

29             loaded = true;

30             $("#box").hide();

31             //$(".loading").remove();

32             $("#DataList").append(result);

33             count++;

34         }

35     });            

36 }
View Code

  服务器端 部分,主要是利用 linq 强大的 OrderByDescending,skip 和 take 方法,把已经加载过的数据过滤掉。

 下载源码

你可能感兴趣的:(asp.net)