angularjs 中实现 load more 功能

在UI 我们经常需要render 一些集合, 如果集合数据过多,那我们可能会采取分页的解决方案,本文是另外一种解决方法,就是当集合数量大于一定数量的时候显示一个 加载更多按钮,点击后,自动加载指定数量的数据。

1. 首先我们创建一个angularjs 页面,让他显示 10条记录:

 

Html page

<div ng-app="APP">
    <h2>angularjs page</h2>
    <div ng-controller="userController">
          <div ng-repeat="user in users">
            {{user.fname}} {{user.lname}}  {{user.zip}} 
        </div>
    </div>
    <hr />
</div>

 

Js file, 在这里我使用了filltext 这个api 来返回模拟数据

var APP = angular.module('APP', []).
controller('userController', function ($scope,$http) {
       $http.jsonp("http://www.filltext.com/?callback=JSON_CALLBACK&rows=10&fname={firstName}&lname={lastName}&zip={zip}").
    success(function (data) {
        $scope.users = data
    })
});

点击地址看预览效果: http://jsfiddle.net/vyhwb3t2/5/

2. 在html page 添加

 <div><button ng-click="loadMore()">load more</button></div>

 

3. 在controller 添加

$scope.loadMore = function(){
  $http.jsonp("http://www.filltext.com/?callback=JSON_CALLBACK&rows=10&fname={firstName}&lname={lastName}&zip={zip}").
  success(function (data) {
    $scope.users = $scope.users.concat(data);
  }
);

ok, 大功告成,是不是非常简单。当然了,在实际情况中,我们还需要根据记录的情形,做些调整,比如显示剩余的记录条数,等数据都加载出来后,就隐藏掉load more 按钮等。

最后 完整代码: http://jsfiddle.net/vyhwb3t2/6/

预览图: 



转载于:https://www.cnblogs.com/slardar1978/p/4203472.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值