最近做的一些小项目中,都有用到分页,需要自己去搞。就把整个分页实现整理下吧,方便自己也方便他人。
前台
1.引入paging.js
//分页,页码导航,要求参数为一个对象
function createPageNav(opt) {
opt= opt || {};
var $container = opt.$container || null, //必需,页码容器,请确保这个容器只用来存放页码导航
pageCount = Number(opt.pageCount) || 0, //必需,页码总数
currentNum = Number(opt.currentNum) || 1, //选填,当前页码
maxCommonLen = Number(opt.maxCommonLen)|| 10, //选填,普通页码的最大个数
className = opt.className || "pagination",//选填,分页类型:pagination或pager等
preText = opt.preText || "上一页", //选填,上一页文字显示,适用于只有前后页按钮的情况
nextText = opt.nextText || "下一页", //选填,下一页文字,同上
firstText = opt.firstText || "首页",
lastText = opt.lastText || "末页",
hasFirstBtn = opt.hasFirstBtn === false "分页容器不存在或不正确");
return false;
}
//总页数
if(pageCount <= 0){
if(noPageFun) noPageFun();
return false;
}
//当前页
if (currentNum < 1) currentNum = 1;
else if (currentNum > pageCount) currentNum = pageCount;
//普通页码的最大个数,起始页算法限制,不能小于3
if(maxCommonLen<3) maxCommonLen=3;
//跳转页响应长度,用于计算起始页码
if(maxCommonLen>=8) changeLen=3;
else if(maxCommonLen>=5) changeLen=2;
else changeLen=1;
$container.hide();
_initPageNav();
$container.show();
function _initPageNav(){
var initStr = [];
initStr.push('<nav><ul class="'+ className +'" onselectstart="return false">');
if(hasFirstBtn)initStr.push('<li class="first-page" value="1"><span>'+ firstText +'</span></li>');
if(hasPreBtn) initStr.push('<li class="pre-page" value="' + (currentNum - 1) + '"><span>'+ preText +'</span></li>');
if(hasNextBtn) initStr.push('<li class="next-page" value="' + (currentNum + 1) + '"><span>'+ nextText +'</span></li>');
if(hasLastBtn) initStr.push('<li class="last-page" value="' + pageCount + '"><span>'+ lastText +'</span></li>');
if(hasInput)
initStr.push('<div class="input-page-div">当前第<input type="text" maxlength="6" value="' + currentNum + '" />页,共<span>'
+ pageCount
+ '</span>页<button type="button" class="btn btn-xs input-btn-xs">确定</button></div>');
initStr.push('</ul></nav>');
$container.html(initStr.join(""));
//初始化变量
$parent=$container.children().children();
if(hasFirstBtn) $firstBtn = $parent.children("li.first-page");
if(hasPreBtn) $preBtn = $parent.children("li.pre-page");
if(hasNextBtn) $nextBtn = $parent.children("li.next-page");
if(hasLastBtn) $lastBtn = $parent.children("li.last-page");
if(hasInput){
$input = $parent.find("div.input-page-div>input");
$parent.find("div.input-page-div>button").click(function(){
_gotoPage($input.val());
});
}
//初始化功能按钮
_buttonToggle(currentNum);
//生成普通页码
if(hasCommonPage) {
_createCommonPage(_computeStartNum(currentNum), currentNum);
}
//绑定点击事件
$parent.on("click", "li",function () {
var $this=$(this);
if ($this.is("li") && $this.attr("value")){
if(!$this.hasClass("disabled") && !$this.hasClass("active")){
_gotoPage($this.attr("value"));
}
}
});
}
//跳转到页码
function _gotoPage(targetNum) {
targetNum=_formatNum(targetNum);
if (targetNum == 0 || targetNum == currentNum) return false;
// 跳转前回调函数
if (beforeFun && beforeFun(targetNum) === false) return false;
//修改值
currentNum=targetNum;
if(hasInput) $input.val(targetNum);
if(hasPreBtn) $preBtn.attr("value", targetNum - 1);
if(hasNextBtn) $nextBtn.attr("value", targetNum + 1);
//修改功能按钮的状态
_buttonToggle(targetNum);
// 计算起始页码
if(hasCommonPage) {
var starNum = _computeStartNum(targetNum);
if (starNum == minNum) {// 要显示的页码是相同的
$currentPage.removeClass("active");
$currentPage = $parent.children("li.commonPage").eq(targetNum - minNum).addClass("active");
}
else {// 需要刷新页码
_createCommonPage(starNum, targetNum);
}
}
// 跳转后回调函数
if (afterFun) afterFun(targetNum);
}
//整理目标页码的值
function _formatNum(num){
num = Number(num);
if(isNaN(num)) num=0;
else if (num <= 0) num = 1;
else if (num > pageCount) num = pageCount;
return num;
}
//功能按钮的开启与关闭
function _buttonToggle(current){
if (current == 1) {
if(hasFirstBtn) $firstBtn.addClass("disabled");
if(hasPreBtn) $preBtn.addClass("disabled");
}
else {
if(hasFirstBtn) $firstBtn.removeClass("disabled");
if(hasPreBtn) $preBtn.removeClass("disabled");
}
if (current == pageCount) {
if(hasNextBtn) $nextBtn.addClass("disabled");
if(hasLastBtn) $lastBtn.addClass("disabled");
}
else {
if(hasNextBtn) $nextBtn.removeClass("disabled");
if(hasLastBtn) $lastBtn.removeClass("disabled");
}
}
//计算当前显示的起始页码
function _computeStartNum(targetNum) {
var startNum;
if (pageCount <= maxCommonLen)
startNum = 1;
else {
if ((targetNum - minNum) >= (maxCommonLen-changeLen)) {//跳转到靠后的页码
startNum = targetNum - changeLen;
if ((startNum + maxCommonLen-1) > pageCount) startNum = pageCount - (maxCommonLen-1);// 边界修正
}
else if ((targetNum - minNum) <= (changeLen-1)) {//跳转到靠前的页码
startNum = targetNum - (maxCommonLen-changeLen-1);
if (startNum <= 0) startNum = 1;// 边界修正
}
else {// 不用改变页码
startNum = minNum;
}
}
return startNum;
}
//生成普通页码
function _createCommonPage(startNum, activeNum) {
var initStr = [];
for (var i = 1,pageNum=startNum; i <= pageCount && i <= maxCommonLen; i++ , pageNum++) {
initStr.push('<li class="commonPage" value="' + pageNum + '"><a href="javascript:" rel="external nofollow" >' + pageNum + '</a></li>');
}
$parent.hide();
$parent.children("li.commonPage").remove();
if(hasPreBtn) $preBtn.after(initStr.join(""));
else if(hasFirstBtn) $firstBtn.after(initStr.join(""));
else $parent.prepend(initStr.join(""));
minNum = startNum;
$currentPage = $parent.children("li.commonPage").eq(activeNum-startNum).addClass("active");
$parent.show();
}
}
2.引入paging.css
ul.pagination>li>span,ul.pagination>li>a,ul.pagination>li.active>a,ul.pager>li>span{
cursor: pointer;
}
.input-page-div>input{
width:5em;
height:1.8em;
margin:0.4em 0.2em 0.2em 0.2em;
text-align: center;
}
.input-page-div>.input-btn-xs{
margin-left:1em;
font-size: 1em;
width:3em;
background-color: #337ab7;
color:#fff;
}
.input-page-div{
display: inline-block;
margin-left:1em;
}
3.页面中添加一个div容器
<div id="paging"></div>
4.js中添加一段代码
createPageNav({
$container : $("#paging"),
pageCount : data.pages,
currentNum : data.pageNum,
afterFun : function(num){
getResult(num,10);
}
});
例:
function getResult(pageNum,pageSize){
$.ajax({
type: "GET",
url: "../../metrics.do"+pageNum+"&pageSize="+pageSize,
data: {},
dataType: "json",
success: function(data){
list = data.data;
createPageNav({
$container : $("#paging"),
pageCount : data.pages,
currentNum : data.pageNum,
afterFun : function(num){
getResult(num,10);
}
});
createList(data.data);
// createSelect(data);
console.info(data);
}
});
}
后台
5.引入pagehelper依赖
<!-- yuruixin add mybatis paging -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>4.1.6</version>
</dependency>
6.service层添加如下代码
//pageSize=0时,查询所有 PageHelper.startPage(pageNum, pageSize); Page<ExtractMetrics> extractMetrics = extractMetricsMapper.selectByCondition(extractMetric,pageNum,pageSize);
7.controller层添加如下代码
Map<String,Object> map = new HashMap<String,Object>();
//查询页数
map.put("pageNum", extractMetrics.getPageNum());
//每页条数
map.put("pageSize", extractMetrics.getPageSize());
//总条数
map.put("total", extractMetrics.getTotal());
//总页数
map.put("pages", extractMetrics.getPages());
map.put("data", extractMetrics.getResult());
至此,bootstrap与pagehelper实现分页流程完毕
效果如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“bootstrap与pagehelper实现分页效果”评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
2025年11月30日
2025年11月30日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]
