angularjs+bootstrap实现自定义分页的实例代码

发布时间 - 2026-01-11 01:57:13    点击率:

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

插件

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

效果图


使用方法

1、在网页的头部引入angularjs、bootstarp以及该插件,该分页插件主要是ng-pagination.css以及ng-pagination.js

<link rel="stylesheet" href="/nutz-test/static/bootstrap/bootstrap.min.css" rel="external nofollow" >
<link rel="stylesheet" href="/nutz-test/static/angular/ng-pagination.css" rel="external nofollow" >
<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>

2、表格代码以及分页代码

<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>

3、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,如下图所示。

2、在ie浏览器和360浏览器不支持跳转功能,原因是ie和360没有number.isNaN()方法,因此需要修改分页插件的该方法,改为isNaN()。

定位到ng-pagination.js的Number.isNaN()方法,把该方法修改为下图所示。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# angularjs  # 自定义分页  # angularjs实现分页  # bootstrap分页  # Spring Boot+AngularJS+BootStrap实现进度条示例代码  # AngularJS实现tab选项卡的方法详解  # Angular2 自定义validators的实现方法  # AngularJS实现单一页面内设置跳转路由的方法  # angular过滤器实现排序功能  # AngularJS实现元素显示和隐藏的几个案例  # AngularJS实现表单验证  # 在AngularJS应用中实现一些动画效果的代码  # AngularJS实现全选反选功能  # 用AngularJS的指令实现tabs切换效果  # 实例详解AngularJS实现无限级联动菜单  # AngularJS实现进度条功能示例  # 分页  # 下一页  # 每页  # 所示  # 就会  # 上一页  # 当你  # 只需  # 是从  # 可以通过  # 尾页  # 做一个  # 不支持  # 跳转  # 就想  # 设置为  # 来实现  # 首页  # 第一页  # 取下 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  Claude怎样写约束型提示词_Claude约束提示词写法【教程】  如何登录建站主机?访问步骤全解析  PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑  详解Android图表 MPAndroidChart折线图  Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】  Laravel如何实现用户密码重置功能?(完整流程代码)  Laravel中的withCount方法怎么高效统计关联模型数量  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布  Python正则表达式进阶教程_复杂匹配与分组替换解析  如何在万网自助建站平台快速创建网站?  如何选择PHP开源工具快速搭建网站?  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  Laravel如何生成URL和重定向?(路由助手函数)  laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法  Laravel怎么实现模型属性的自动加密  Laravel如何实现模型的全局作用域?(Global Scope示例)  如何在建站宝盒中设置产品搜索功能?  laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法  如何快速完成中国万网建站详细流程?  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  jQuery validate插件功能与用法详解  如何基于PHP生成高效IDC网络公司建站源码?  JavaScript Ajax实现异步通信  Laravel项目怎么部署到Linux_Laravel Nginx配置详解  教你用AI将一段旋律扩展成一首完整的曲子  Linux网络带宽限制_tc配置实践解析【教程】  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  企业网站制作这些问题要关注  魔方云NAT建站如何实现端口转发?  使用Dockerfile构建java web环境  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  音乐网站服务器如何优化API响应速度?  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  用v-html解决Vue.js渲染中html标签不被解析的问题  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  千库网官网入口推荐 千库网设计创意平台入口  制作电商网页,电商供应链怎么做?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  手机网站制作与建设方案,手机网站如何建设?  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  网站制作壁纸教程视频,电脑壁纸网站?