需要用到的js

angular.js(用angular.min.js会导致分页控件不显示)
ui-bootstrap-tpls.min.js
angular-animate.js
需要用到的css
bootstrap.min.css
由于本项目使用了路由,所以讲js以及css文件的应用都放在一个主html,请同学们在html页面中添加以上文件
在开始之前,我先简单介绍下分页的原理。
分页的实质其实就是一条sql语句,
比如查找第二页,即第16到第30条数据
在MySQL中是select * from table limit 15,15 order by id desc
Sql server中是select * from (select top 15 * from (select top (30) * from table order by id desc) order by available asc) order by id desc Oracle是(oracle中的row从1开始):select * from (select a.*,rownum from (select * from tablet order by id desc) a ) b where b.rownum between 16 and 30
一般情况下,查询得到的数据采用倒序排序,这样可以将用户最新插入的数据放在最前面。
那么这三条sql语句中的这些数值是怎么计算得到的呢?它们就是根据1、CurrentPage 当前在哪一页 2、PageSize 每页展示多少条 来的到的,因此后台需要从前端获取这两个数值。又为了告诉用户一共有多少页,我们还要3、TotalSize 一共多少条 。
现在有了上面1 2 3值,我们就可以来进行分页了。在前端我们需要一个Table来帮我们展示数据,还需要一个小控件,让用户去选择第几页,而bootstrap就为我们提供了这个小控件(uib-pagination),大大减轻了我们的工作量。在后端Jpa又为我们提供了分页接口,我们只需要继承JapRepository即可,零代码量!
下面就重点看Table、uib-pagination以及JapRepository提供的接口的用法。
html页面代码:
<div data-ng-controller="QuestionCtrl" class="container" style="width: 1900px;">
<br>
<table class="table table-bordered table-hover ">
<thead>
<tr>
<th class="text-center"><input type="checkbox"
data-ng-model="allChecked" data-ng-change="checkAll(allChecked)" /></th>
<th class="text-center">序号</th>
<th class="text-center">题目</th>
<th class="text-center">A</th>
<th class="text-center">B</th>
<th class="text-center">C</th>
<th class="text-center">D</th>
<th class="text-center">答案</th>
<th class="text-center">答题数</th>
<th class="text-center">正确数</th>
<th class="text-center">正确率</th>
</tr>
</thead>
<tbody>
<tr data-ng-repeat="item in items">
<td class="text-center"><input type="checkbox"
data-ng-model="item.$checked" data-ng-changed="checkedChange(item.id,item.$checked)"/></td>
<td class="text-center"><span data-ng-bind="$index+1"></span></td>
<td class="text-center"
data-ng-bind="item.test"></td>
<td class="text-center" data-ng-bind="item.op1"></td>
<td class="text-center" data-ng-bind="item.op2"></td>
<td class="text-center" data-ng-bind="item.op3"></td>
<td class="text-center" data-ng-bind="item.op4"></td>
<td class="text-center" data-ng-bind="item.answer"></td>
<td class="text-center" data-ng-bind="item.total"></td>
<td class="text-center" data-ng-bind="item.totalCorrect"></td>
<td class="text-center">
<span data-ng-if="item.total!=0" data-ng-bind="item.totalCorrect / item.total * 100 | number:2 "></span>
<span data-ng-if="item.total==0" data-ng-bind="0"></span>
%</td>
</tr>
</tbody>
</table>
<div class="text-right">
<button class="btn btn-defualt" style="float: left" data-ng-click="deleteItems()">删除</button>
<span style="color:#ff0000;"><uib-pagination total-items="TotalItems" ng-model="currentPage" items-per-page = "numPerPage" max-size="maxSize" class="pagination" first-text="首页" previous-text="上一页" next-text="下一页" last-text="末页" boundary-links="true" ng-change="pageChanged()" force-ellipses="false"></uib-pagination></span>
</div>
</div>
分页是通过 uib-pagination 标签来实现的,用到标签属性有:
total-items:表示总共有多少条记录
items-per-page:每一页显示多少条记录
max-size:决定用户看到的页数,即选择页面的按钮,不理解的同学可以调整这个数值查看变化
ng-model:当前所在页面
以上4个属性的值与js双向绑定
boundary-link:显示“首页”、“末页”按钮
force-ellipses:当值为true时,超过max-size的也会以省略号的形式展现
js代码如下:
var app = angular.module("APP",['ui.bootstrap', 'ngAnimate']);
app.controller('QuestionCtrl', function($scope, $uibModal, $http) {
<span style="color:#ff0000;">$scope.currentPage = 1;//当前页
$scope.numPerPage = 15;
$scope.maxSize = 5;
$http({
url : '/getExamsByPage',
method : 'post',
params : {
'currentPage' : $scope.currentPage - 1,
'numPerPage' : $scope.numPerPage
}
}).success(function(response) {
$scope.TotalItems = response.totalElements;
$scope.items = response.content;
});
$scope.pageChanged = function() {
$http({
url : '/getExamsByPage',
method : 'post',
params : {
'currentPage' : $scope.currentPage - 1,
'numPerPage' : $scope.numPerPage
}
}).success(function(response) {
$scope.TotalItems = response.totalElements;
$scope.items = response.content;
});
}</span>
$scope.checkAll = function(checked) {
angular.forEach($scope.items, function(item) {
item.$checked = checked;
});
};
$scope.deleteExam = function(id) {
$http({
url : '/deleteexam',
method : 'post',
params : {
'id' : id,
'currentPage' : $scope.currentPage - 1,
'numPerPage' : $scope.numPerPage
}
}).success(function(response) {
$scope.TotalItems = response.totalElements;
$scope.items = response.content;
});
}
$scope.deleteItems = function() {
var checkedlist = new Array();
angular.forEach($scope.items, function(item) {
if (item.$checked == true)
checkedlist.push(item.id);
});
$http({
url : "/deleteexams",
method : "post",
params : {
'ids' : checkedlist,
'currentPage' : $scope.currentPage - 1,
'numPerPage' : $scope.numPerPage
}
}).success(function(response) {
$scope.TotalItems = response.totalElements;
$scope.items = response.content;
});
};
});
每次请求后台需要将当前页以及每页的数量发送到后台。
前台接受到的json数据是这样的
{"content":[{"id":225,"test":"办公自动化是计算机的一项应用,按计算机应用分类,它属于____。","op1":"数据处理","op2":"科学计算","op3":"实时控制","op4":"辅助设计","answer":"A","total":2,"totalCorrect":1},{"id":224,"test":"软件由___和文档两部分组成。","op1":"数据","op2":"指令","op3":"程序","op4":"工具","answer":"C","total":2,"totalCorrect":1},{"id":223,"test":"为达到某一目的而编写的计算机指令序列称为____。","op1":"软件","op2":"字符串","op3":"程序","op4":"命令","answer":"C","total":2,"totalCorrect":1},{"id":222,"test":"办公自动化是计算机的一项应用,按计算机应用分类,它属于____。","op1":"数据处理","op2":"科学计算","op3":"实时控制","op4":"辅助设计","answer":"A","total":2,"totalCorrect":1},{"id":220,"test":"为达到某一目的而编写的计算机指令序列称为____。","op1":"软件","op2":"字符串","op3":"程序","op4":"命令","answer":"C","total":2,"totalCorrect":1},{"id":219,"test":"办公自动化是计算机的一项应用,按计算机应用分类,它属于____。","op1":"数据处理","op2":"科学计算","op3":"实时控制","op4":"辅助设计","answer":"A","total":2,"totalCorrect":1},{"id":218,"test":"软件由___和文档两部分组成。","op1":"数据","op2":"指令","op3":"程序","op4":"工具","answer":"C","total":2,"totalCorrect":1},{"id":217,"test":"为达到某一目的而编写的计算机指令序列称为____。","op1":"软件","op2":"字符串","op3":"程序","op4":"命令","answer":"C","total":2,"totalCorrect":1},{"id":216,"test":"办公自动化是计算机的一项应用,按计算机应用分类,它属于____。","op1":"数据处理","op2":"科学计算","op3":"实时控制","op4":"辅助设计","answer":"A","total":2,"totalCorrect":1},{"id":215,"test":"软件由___和文档两部分组成。","op1":"数据","op2":"指令","op3":"程序","op4":"工具","answer":"C","total":2,"totalCorrect":1}],"last":false,"totalPages":9,"totalElements":86,"number":0,"size":10,"sort":[{"direction":"DESC","property":"id","ignoreCase":false,"nullHandling":"NATIVE","ascending":false}],"numberOfElements":10,"first":true}
后台controller代码
@RequestMapping(value = "/getExamsByPage")
@ResponseBody
public Page<Exam> getExamsByPage(@RequestParam(value = "currentPage",defaultValue = "0") Integer page,
@RequestParam(value = "numPerPage",defaultValue = "10") Integer pageSize) {
Sort sort = new Sort(Direction.DESC, "id");//设置排序方式
Pageable pageable = new PageRequest(page, pageSize, sort);//构建Pageable对象,改分页查询是通过jpa的PagingAndSortingRepository接口完成的
Page<Exam> Exams = examrepository.findAll(pageable);
return Exams;
}
repository代码:
@Transactional
public interface ExamRepository extends JpaRepository<Exam, Integer> {
}
contoller中调用的findAll方法是PagingAndSortingRepository实现的,但是JpaRepository继承自PagingAndSortingRepository,因此也有findAll方法,不明白的同学可以去查阅改接口的资料。
这样就完成了分页显示,图片如下
总结
以上所述是小编给大家介绍的Angular+Bootstrap+Spring Boot实现分页功能实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# angular
# bootstrap
# spring
# boot
# 分页
# SpringBoot与Angular2的集成示例
# Spring Boot+AngularJS+BootStrap实现进度条示例代码
# 玩转spring boot 结合AngularJs和JDBC(4)
# 玩转spring boot 结合jQuery和AngularJs(3)
# 详解springboot和vue前后端分离开发跨域登陆问题
# SpringBoot+Vue.js实现前后端分离的文件上传功能
# vue+springboot前后端分离实现单点登录跨域问题解决方法
# spring boot+vue 的前后端分离与合并方案实例详解
# springboot+angular4前后端分离 跨域问题解决详解
# 数据处理
# 计算机应用
# 办公自动化
# 两部分
# 放在
# 每页
# 文档
# 首页
# 末页
# 小编
# 又为
# 也有
# 下一页
# 在此
# 是这样
# 上一页
# 是怎么
# 当前页
# 不明白
相关文章:
如何在万网开始建站?分步指南解析
如何基于PHP生成高效IDC网络公司建站源码?
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
高防服务器租用如何选择配置与防御等级?
成都品牌网站制作公司,成都营业执照年报网上怎么办理?
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
如何快速选择适合个人网站的云服务器配置?
建站之星logo尺寸如何设置最合适?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
如何快速搭建响应式可视化网站?
创业网站制作流程,创业网站可靠吗?
香港服务器部署网站为何提示未备案?
公司网站的制作公司,企业网站制作基本流程有哪些?
制作农业网站的软件,比较好的农业网站推荐一下?
如何在七牛云存储上搭建网站并设置自定义域名?
桂林网站制作公司有哪些,桂林马拉松怎么报名?
网站制作壁纸教程视频,电脑壁纸网站?
如何通过多用户协作模板快速搭建高效企业网站?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
广州美橙建站如何快速搭建多端合一网站?
简单实现Android文件上传
免费网站制作appp,免费制作app哪个平台好?
山东云建站价格为何差异显著?
如何配置IIS站点权限与局域网访问?
广东专业制作网站有哪些,广东省能源集团有限公司官网?
如何在服务器上三步完成建站并提升流量?
Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解
建站之星云端配置指南:模板选择与SEO优化一键生成
盘锦网站制作公司,盘锦大洼有多少5G网站?
高防服务器租用指南:配置选择与快速部署攻略
深圳网站制作的公司有哪些,dido官方网站?
金*站制作公司有哪些,金华教育集团官网?
C++如何使用std::optional?(处理可选值)
建站之星如何快速生成多端适配网站?
哈尔滨网站建设策划,哈尔滨电工证查询网站?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
如何用花生壳三步快速搭建专属网站?
建站主机与虚拟主机有何区别?如何选择最优方案?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
制作网站的模板软件,网站怎么建设?
成都响应式网站开发,dw怎么把手机适应页面变成网页?
如何选择适合PHP云建站的开源框架?
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
教学网站制作软件,学习*后期制作的网站有哪些?
如何获取开源自助建站系统免费下载链接?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
如何在阿里云服务器自主搭建网站?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
c# F# 的 MailboxProcessor 和 C# 的 Actor 模型
*请认真填写需求信息,我们会在24小时内与您取得联系。