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

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

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

  主要有2种形式。

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

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

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

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

  

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

  

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

  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 方法,把已经加载过的数据过滤掉。

 下载源码

posted @ 2013-06-13 17:56  geass..  阅读(3858)  评论(3编辑  收藏  举报