目前在做一个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实现进度条功能示例
# 分页
# 下一页
# 每页
# 所示
# 就会
# 上一页
# 当你
# 只需
# 是从
# 可以通过
# 尾页
# 做一个
# 不支持
# 跳转
# 就想
# 设置为
# 来实现
# 首页
# 第一页
# 取下
相关文章:
Python文件管理规范_工程实践说明【指导】
简历在线制作网站免费版,如何创建个人简历?
建站之星代理如何优化在线客服效率?
网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?
制作国外网站的软件,国外有哪些比较优质的网站推荐?
如何在阿里云高效完成企业建站全流程?
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
如何用y主机助手快速搭建网站?
php条件判断怎么写_ifelse和switchcase的使用区别【对比】
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
利用JavaScript实现拖拽改变元素大小
宁波免费建站如何选择可靠模板与平台?
整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?
魔毅自助建站系统:模板定制与SEO优化一键生成指南
专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
建站之星免费模板:自助建站系统与智能响应式一键生成
安徽网站建设与外贸建站服务专业定制方案
网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
长沙企业网站制作哪家好,长沙水业集团官方网站?
公众号网站制作网页,微信公众号怎么制作?
电商网站制作价格怎么算,网上拍卖流程以及规则?
上海网站制作网站建设公司,建筑电工证网上查询系统入口?
建站之星备案流程有哪些注意事项?
Python路径拼接规范_跨平台处理说明【指导】
如何高效利用亚马逊云主机搭建企业网站?
制作网站的基本流程,设计网站的软件是什么?
常州自助建站费用包含哪些项目?
如何选择适合PHP云建站的开源框架?
个人网站制作流程图片大全,个人网站如何注销?
如何选择香港主机高效搭建外贸独立站?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
广平建站公司哪家专业可靠?如何选择?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
智能起名网站制作软件有哪些,制作logo的软件?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
如何在香港服务器上快速搭建免备案网站?
外贸公司网站制作哪家好,maersk船公司官网?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
香港服务器网站推广:SEO优化与外贸独立站搭建策略
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
小程序网站制作需要准备什么资料,如何制作小程序?
长沙做网站要多少钱,长沙国安网络怎么样?
实例解析Array和String方法
建站之星如何实现PC+手机+微信网站五合一建站?
香港网站服务器数量如何影响SEO优化效果?
html制作网站的步骤有哪些,iapp如何添加网页?
深入理解Android中的xmlns:tools属性
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
*请认真填写需求信息,我们会在24小时内与您取得联系。