angular.js分页代码的实例


Posted in Javascript onJuly 27, 2016

对于大多数web应用来说显示项目列表是一种很常见的任务。通常情况下,我们的数据会比较多,无法很好地显示在单个页面中。在这种情况下,我们需要把数据以页的方式来展示,同时带有转到上一页和下一页的功能。现在在学习angular,使用angularjs 分页,基于 directive 实现,样式使用的 bootstrap,直接在 html代码中加入 标签即可调用。

先来看下效果图

angular.js分页代码的实例

实例代码

app.directive('pagePagination', function(){
  return {
    restrict : 'E',
    template : '<div class="pagination-box"><ul class="pagination"><li ng-class="page.style" ng-repeat="page in pageList"><a href="{{ page.link }}">{{ page.name }}</a></li></ul><ul class="pagination" ng-if="pageList[0]"><li class="page-count disabled"><span>共 <b>{{ pageRecord }}</b> 条记录 / 共 <b>{{ pageCount }}</b> 页</span></li></ul></div>',
    replace : true,
    scope : {
      "pageId"      : "=",
      "pageRecord"    : "=",
      "pageSize"     : "=",
      "pageUrlTemplate"  : "="
    },
    controller : ['$scope', function($scope){
       
      $scope.getLink = function(pageId){
        return $scope.pageUrlTemplate.replace("{PAGE}", pageId);
      };
 
      $scope.getPageList = function(){
        var page = [];
        var firstPage = parseInt(( $scope.pageId - 1 ) / $scope._pageSize ) * $scope._pageSize + 1;
        page.push({
          name  : '首页',
          style  : $scope.pageId == 1 ? "disabled" : "",
          link  : $scope.getLink(1)
        });
        page.push({
          name  : '上一页',
          style  : $scope.pageId == 1 ? "disabled" : "",
          link  : $scope.getLink(1)
        });
        for( var pageId = firstPage; pageId < firstPage + 10; pageId ++){
          if( pageId >= 1 && pageId <= $scope.pageCount ){
            page.push({
              name  : pageId,
              link  : $scope.getLink(pageId),
              style  : pageId == $scope.pageId ? "active" : ""
            });
          }
        }
        page.push({
          name  : '下一页',
          style  : $scope.pageId == $scope.pageCount ? "disabled" : "",
          link  : $scope.getLink($scope.pageCount)
        });
        page.push({
          name  : '尾页',
          style  : $scope.pageId == $scope.pageCount ? "disabled" : "",
          link  : $scope.getLink($scope.pageCount)
        });
        return page;
      };
 
      $scope.pageInit = function(){
        if( !$scope.pageId || !$scope.pageRecord ){
          setTimeout(function(){
            $scope.$apply(function(){
              $scope.pageInit();
            });
          }, 10);
        }else{
          if( !!$scope.pageSize ){
            $scope._pageSize = parseInt($scope.pageSize);
          }else{
            $scope._pageSize = 10;
          }
          $scope.pageId    = parseInt($scope.pageId);
          $scope.pageCount  = parseInt(( $scope.pageRecord - 1 ) / $scope._pageSize ) + 1;
          if( $scope.pageId < 1 ){
            $scope.pageId = 1;
          }else if( $scope.pageId > $scope.pageCount ){
            $scope.pageId = $scope.pageCount;
          }
          $scope.pageLoad   = true;
          $scope.pageList   = $scope.getPageList();
        }
      };
       
      $scope.pageLoad = false;
      $scope.pageInit();
    }]
  }
});

调用代码:

<page-pagination
  page-id="pageId"
  page-record="recordCount"
  page-url-template="urlTemplate">
</page-pagination>

以上就是angular.js分页代码的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery创建插件的代码分析
Apr 14 Javascript
ie下$.getJSON出现问题的解决方法
Feb 12 Javascript
JS中FRAME的操作问题实例分析
Oct 21 Javascript
javascript如何实现暂停功能
Nov 06 Javascript
jQuery模拟Marquee实现无缝滚动效果完整实例
Sep 29 Javascript
bootstrap输入框组件使用方法详解
Jan 19 Javascript
vue轮播图插件vue-awesome-swiper
Nov 27 Javascript
JavaScript中Object值合并方法详解
Dec 22 Javascript
axios全局请求参数设置,请求及返回拦截器的方法
Mar 05 Javascript
js实现input密码框显示/隐藏功能
Sep 10 Javascript
koa+jwt实现token验证与刷新功能
May 30 Javascript
VUE使用axios调用后台API接口的方法
Aug 03 Javascript
jQuery基于函数重载实现自定义Alert函数样式的方法
Jul 27 #Javascript
jquery动态遍历Json对象的属性和值的方法
Jul 27 #Javascript
移动端翻页插件dropload.js(支持Zepto和jQuery)
Jul 27 #Javascript
js中遍历对象的属性和值的方法
Jul 27 #Javascript
js中的关联数组与普通数组详解
Jul 27 #Javascript
20分钟打造属于你的Bootstrap站点
Jul 27 #Javascript
浅谈js多维数组和hash数组定义和使用
Jul 27 #Javascript
You might like
php 中英文语言转换类
2011/09/07 PHP
CodeIgniter生成网站sitemap地图的方法
2013/11/13 PHP
PHP FTP操作类代码( 上传、拷贝、移动、删除文件/创建目录)
2014/05/10 PHP
php中限制ip段访问、禁止ip提交表单的代码分享
2014/08/22 PHP
PHP魔术方法的使用示例
2015/06/23 PHP
CI框架文件上传类及图像处理类用法分析
2016/05/18 PHP
PHP最常用的正则表达式
2017/02/13 PHP
php引用和拷贝的区别知识点总结
2019/09/23 PHP
laravel使用数据库测试注意事项
2020/04/10 PHP
用javascript获取地址栏参数
2006/12/22 Javascript
Google Map V3 绑定气泡窗口(infowindow)Dom事件实现代码
2013/04/26 Javascript
html的DOM中Event对象onblur事件用法实例
2015/01/21 Javascript
JS实战篇之收缩菜单表单布局
2016/12/10 Javascript
AngularJS实现根据不同条件显示不同控件
2017/04/20 Javascript
angular ng-click防止重复提交实例
2017/06/16 Javascript
JS实现的加减乘除四则运算计算器示例
2017/08/09 Javascript
JavaScript+CSS相册特效实例代码
2017/09/07 Javascript
Vue+Vux项目实践完整代码
2017/11/30 Javascript
react-router4 配合webpack require.ensure 实现异步加载的示例
2018/01/18 Javascript
vue axios整合使用全攻略
2018/05/24 Javascript
实现一个 Vue 吸顶锚点组件方法
2019/07/10 Javascript
[02:34]肉山说——泡妞篇
2014/09/16 DOTA
Ruby使用eventmachine为HTTP服务器添加文件下载功能
2016/04/20 Python
Python的Tornado框架实现异步非阻塞访问数据库的示例
2016/06/30 Python
Python装饰器用法实例总结
2018/02/07 Python
python 使用pdfminer3k 读取PDF文档的例子
2019/08/27 Python
Python closure闭包解释及其注意点详解
2019/08/28 Python
Python中zip函数如何使用
2020/06/04 Python
Python通过类的组合模拟街道红绿灯
2020/09/16 Python
Argos官网:英国家喻户晓的百货零售连锁商
2017/04/03 全球购物
Champs Sports加拿大:北美最大的以商场为基础的专业运动鞋和服装零售商之一
2018/05/01 全球购物
武侯祠导游词
2015/02/04 职场文书
工作时间调整通知
2015/04/24 职场文书
标准演讲稿格式结尾应该怎么书写?
2019/07/17 职场文书
jQuery实现影院选座订座效果
2021/04/13 jQuery
Fluentd搭建日志收集服务
2022/09/23 Servers