angularjs+bootstrap自定义分页

目前在做一个java web页面,没有使用到框架的分页,所以需要自己实现分页,就想到了用angularjs来实现分页,数据通过ajax从后台获取。

插件

百度了一下,看到一个比较漂亮的插件,就直接用该插件,并修改了部分细节,使得适合我的项目,该插件地址是:(https://github.com/miaoyaoyao/AngularJs-UI

效果图

Paste_Image.png

使用方法

  1. 在网页的头部引入angularjs、bootstarp以及该插件,该分页插件主要是ng-pagination.css以及ng-pagination.js
<link rel="stylesheet" href="/nutz-test/static/bootstrap/bootstrap.min.css">
<link rel="stylesheet" href="/nutz-test/static/angular/ng-pagination.css">
<script src="/nutz-test/static/jquery/jquery.min.js"></script>
<script src="/nutz-test/static/angular/angular.min.js"></script>
<script src="/nutz-test/static/angular/ng-pagination.js"></script>
<script src="/nutz-test/static/bootstrap/bootstrap.min.js"></script>
  1. 表格代码以及分页代码
<div id="app" ng-app="myApp" ng-controller="myCtrl">
    <div style="overflow: auto; width: 100%;">
        <table class="table table-hover table-striped table-bordered" id="j-table">
            <thead>
                <tr>
                    <th>姓名</th>
                    <th>年龄</th>
                    <th>电话</th>
                    <th>职位</th>
                </tr>        
            </thead>
            <tbody>
                <tr ng-repeat="item in list">
                    <th title="{{item.name}}">{{item.name}}</th>
                    <th title="{{item.age}}">{{item.age}}</th>
                    <th title="{{item.tel}}">{{item.tel}}</th>
                    <th title="{{item.position}}">{{item.position}}</th>
                </tr>
            </tbody>
        </table>
    </div>
<!-- 这里引用插件的分页-->
    <div class="pager">
      <pager page-count="pageCount" current-page="currentPage" on-page-change="onPageChange()" first-text="首页" next-text="下一页" prev-text="上一页" last-text="尾页" show-goto="true" goto-text="跳转到"></pager>
    </div>
</div>
  1. javascript代码部分

分页的重点是从后台获取数据,只需把pageSize(每页显示数目),以及pageIndex(当前页数)通过post请求传到后台即可。后台返回实际的数据以及pageCount(页数)给前台即可。其中,onPageChange()方法是点击页码后去通过ajax从后台获取数据,myinit()方法是第一次请求该页面时进行初始化。$scope.currentPage就是页数,例如当你点击下一页的时候,它就会加一,然后就可以通过post请求去后台取下一页的数据了。

<script type="text/javascript">
var app = angular.module('myApp', ['ng-pagination']);
app.controller('myCtrl', ['$scope', function ($scope) {
    $scope.onPageChange = function() {
          // ajax request to load data
          console.log($scope.currentPage);
          //这里是post请求去后台取数据
          $.ajax({
              type:"post",
              url:'/nutz-test/show/pagination',
              data:{
                  "pageSize":5,
                  "pageIndex":$scope.currentPage
              },
              dataType:"json",
              success:function(data){
                  $scope.$apply(function () {
                      $scope.list = data.list;
                      $scope.pageCount = data.pageCount;
                    });
                  
              }
          })
        };
        //初始化,设置为第一页,每页显示5条
        $scope.myinit = function(){
            $.ajax({
                  type:"post",
                  url:'/nutz-test/show/pagination',
                  data:{
                      "pageSize":5,
                      "pageIndex":1
                  },
                  dataType:"json",
                  success:function(data){
                      $scope.$apply(function () {
                          $scope.list = data.list;
                          $scope.pageCount = data.pageCount;
                        });
                      
                  }
              })
        };
        $scope.myinit();
}]);
</script>

注意事项

  1. 该插件在只有一页的情况会出现分页插件加载不出来的情况,因此需要修改ng-pagination.js的代码。
打开ng-pagination.js,定位到最后的template,修改pageCount>=1,如下图所示。
Paste_Image.png
  1. 在ie浏览器和360浏览器不支持跳转功能,原因是ie和360没有number.isNaN()方法,因此需要修改分页插件的该方法,改为isNaN()。
定位到ng-pagination.js的Number.isNaN()方法,把该方法修改为下图所示。
Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • AngularJS是什么?AngularJs(后面就简称ng了)是一个用于设计动态web应用的结构框架。首先,它是...
    200813阅读 1,668评论 0 3
  • 通过AngularJS仿豆瓣一刻的案例:https://github.com/zhongxiaolian/doub...
    中小恋阅读 1,807评论 1 21
  • 第5章 菜单、按钮及导航 一、下拉菜单 小伙伴们注意,在Bootstrap框架中的下拉菜单组件是一个独立的组件,根...
    凛0_0阅读 5,100评论 0 66
  • 要死,昨天前天两天没写日记,不是不想写,压根就忘了有这个事。我写日记主要是想坚持记录每天的一些小事,前两...
    天空蓝上阅读 306评论 0 0
  • 一.最近的目标:伴侣 二.需要重下的种子:爱与陪伴,智慧,温暖 三.具体的播种行为 1.给隔壁可可和多多送零食吃,...
    柔光宝宝阅读 107评论 0 0