PS:前面忘了给大家讲解后台需要做的 ,同步分页的时候,我们只需要定义一个方法,给前台传递一个page对象,前台接收到直接展示即可;异步分页要多一步,首先还是写一个方法,传递初始对象,后面的ajax返回的时候需要再定义一个方法,作为分页数据刷新。

  上一篇文章为给大家讲到了同步分页,封装完整,复用性高,但是缺点就是每次点击的时候需要刷新整个界面,碍于开发的需要,当某些界面存在几个分页的时候缺点就出来了,于是又在这个基础上做了一些小调整,使用了ajax的方式,实现局部刷新分页,现在把代码给大家共享一下:

1、JSP页面跟同步分页差不多

a)、不在只是局限于只定义一个form表单,可以在每个需要分页的地方都写一个;

<div>
<div class="color size14" style="margin-top: 95px">
账号记录
</div>
<div class="table-responsive" style="margin-top: 20px;margin-left: 0">
<table id="sample-table-1" class="table table-striped table-bordered table-hover" style="margin-left: 0"> <thead>
<tr>
<th>序号</th>
<th>操作人</th>
<th>操作时间</th>
<th>操作描述</th>
<th>内容</th>
<th>结果</th>
</tr>
</thead>
<tbody id="operLog-tbody">
<%--分页内容--%>
<c:forEach items="${operLogPage.list}" var="operlog" varStatus="status">
<tr>
<td>${status.index+1}</td>
<td>${operlog.operater}</td>
<td>${operlog.updateTime}</td>
<td>${operlog.remark}</td>
<td>${operlog.operName}</td>
<td>${operlog.result}</td>
</tr>
</c:forEach>
</tbody>
</table>
</div>
<div class="page">
<form class="submitPage operlogForm" action="${ctx}/admin/userManage/getOperLogPagination" > </form>
</div>
</div>

  2、将同步分页的page.js里面的整体封装成一个方法,方便重复调用:

<!--基本信息分页-->
function getOperlogPage(operlogCurpage,operlogTotalPage,formName) {
var curPageNum = 1;
var curtotalpage = 4;
curPageNum = operlogTotalPage;
//前5页//后5页
//需要计算开始页数
var startpage = 1; if (operlogCurpage == null) {
operlogCurpage = 1;
}
if (operlogCurpage <= 3) {
startpage = 1;
} else {
startpage = operlogCurpage - 3 + startpage;
}
var prepage = operlogCurpage - 1;
var nextpage = parseInt(operlogCurpage) + 1;
var endpage = startpage + curtotalpage;
if (endpage > operlogTotalPage) {
endpage = operlogTotalPage;
}
var front = operlogCurpage - 3;
var back = parseInt(operlogCurpage) + 2;
//上一页
if (prepage >= 1) {
var prepage = '<input class="inp pages" id="oper_pre" type="button" value="上一页" onclick="nextOperlogPageToForm(' + prepage + ')">';
$(prepage).appendTo(formName);
}
//前省略
if (front > 0) {
var qiandian = '<input class="inp nob" type="button" value="1" onclick="nextOperlogPageToForm(1)">';
qiandian += '<input class="inp dian mr" type="button" value="..."> ';
formName.append(qiandian);
}
//页码
for (var i = startpage; i <= endpage; i++) {
var wtpage = null;
if (i == operlogCurpage) {
wtpage = '<input class="inp nob active" type="button" value="' + i + '" onclick="nextOperlogPageToForm(' + i + ')">';
} else {
wtpage = '<input class="inp nob" type="button" value="' + i + '" onclick="nextOperlogPageToForm(' + i + ')">';
}
$(wtpage).appendTo(formName);
}
//后省略
if (back < operlogTotalPage && operlogTotalPage > 5) {
var houdian = '<input class="inp dian mr" type="button" value="..."> ';
houdian += '<input class="inp nob" type="button" value="' + operlogTotalPage + '" id="oper_total" onclick="nextOperlogPageToForm(1)">';
formName.append(houdian);
}
//下一页
if (nextpage <= operlogTotalPage) {
var nextcontent = '<input class="inp pages" id="oper_next" type="button" value="下一页" onclick="nextOperlogPageToForm(' + nextpage + ')" >';
$(nextcontent).appendTo(formName);
}
//跳转页码
var pageNum1 = '  第  <input class="inp nob inner" type="text" id="operlog-input" value="' + operlogCurpage + '" >  页  ';
formName.append(pageNum1);
var pageNum2 = '<a href="javascript:jumpOperlog();" class="color6">跳转</a>';
formName.append(pageNum2); }

  3、JSP页面调用方法:

 var curPageNum=1;
getOperlogPage('${operLogPage.pageNo}','${operLogPage.totalPage}',$(".operlogForm"));

  4、ajax分页:

 //上一页/下一页 首页/尾页 适用于带form参数
function nextOperlogPageToForm(pageNo){
if( $(document).find(".operlogForm").length > 0){ $("<input id='pageNo' name='pageNo' type='hidden' value=\""+pageNo+"\">").appendTo(".operlogForm");
$.ajax({
type: "POST",
url: "${ctx}/admin/userManage/getOperLogPagination",
data: {
id:${model.id},
pageNo:pageNo
},
success:function(data){
$("#sample-table-1 tr:not(:first)").html("");
var operLogVo = data.list;
for(var i = 0;i<operLogVo.length;i++){
$("#operLog-tbody").append(" "
+" <tr>"
+"<td>"+(i+1)+"</td>"
+"<td>"+(operLogVo[i].operater)+"</td>"
+"<td>"+(operLogVo[i].updateTime)+"</td>"
+"<td>"+(operLogVo[i].remark)+"</td>"
+"<td>"+(operLogVo[i].operName)+"</td>"
+"<td>"+(operLogVo[i].result)+"</td>"
);
} }
});
$(".operlogForm").empty();
getOperlogPage(pageNo,'${operLogPage.totalPage}',$(".operlogForm"));
/* $(".operlogForm").find('.nob').removeClass('active');
$(".operlogForm").find('input[value="'+pageNo+'"]').addClass('active');*/
}
}

  5、效果与前者一样,还是给大家看看图片

项目开发之分页---异步分页(ajax)的更多相关文章

  1. 项目:《ssh框架综合项目开发视频》-视频目录和第六天的EasyUI简单讲解

    4 练习使用技术: Struts2 + hibernate5.x + spring4.x + mysql数据库 1 crm:customer relational manager,客户关系管理 2 c ...

  2. 5.Hibernate实现全套增删改查和ajax异步分页

    1.1 创建如下oracle数据库脚本 drop sequence seq_stu; create sequence SEQ_STU minvalue maxvalue start increment ...

  3. jQuery+Ajax+PHP实现异步分页数据显示

    这几天做毕业设计的时候需要使用到一个异步分页的功能,即翻页的时候只是刷新分页的数据而不是刷新整个页面.因为之前做项目的时候没有做过这方面的功能,所以还是纠结了挺长时间的,在网上也找了很多资料,结合自己 ...

  4. 向上滚动或者向下滚动分页异步加载数据(Ajax + lazyload)[上拉加载组件]

    /**** desc : 分页异步获取列表数据,页面向上滚动时候加载前面页码,向下滚动时加载后面页码 ajaxdata_url ajax异步的URL 如data.php page_val_name a ...

  5. 利用Linq + Jquery + Ajax 异步分页的实现

    在Web显示的时候我们经常会遇到分页显示,而网上的分页方法甚多,但都太过于消耗带宽,所以我想到了用Ajax来分页,利用返回的Json来处理返回的数据, 大大简化了带宽的压力. 先说下思路,无非就是异步 ...

  6. SPA项目开发之动态树+数据表格+分页

    SPA项目开发之动态树+数据表格+分页 动态生成NavMenu导航菜单(只支持2级菜单) <el-menu key="" index=""> < ...

  7. SPA项目开发动态树、数据表格、分页功能

    SPA项目开发 1.修改左侧动态树 LeftNav.vue <template> <el-menu router :" class="el-menu-vertic ...

  8. Java项目开发中实现分页的三种方式一篇包会

    前言   Java项目开发中经常要用到分页功能,现在普遍使用SpringBoot进行快速开发,而数据层主要整合SpringDataJPA和MyBatis两种框架,这两种框架都提供了相应的分页工具,使用 ...

  9. Spring+Mybatis+jQuery.Pagination.js异步分页及JsonConfig的使用

    在开发工作中经常用到异步分页,这里简单整理一下资料. 一.Controller方法 package com.lwj.controller; import javax.servlet.http.Http ...

随机推荐

  1. 关于Java String对象创建的几点疑问

    我们通过JDK源码会知道String实质是字符数组,而且是不可被继承(final)和具有不可变性(immutable).可以如果想要了解String的创建我们需要先了解下JVM的内存结构. 1.JVM ...

  2. firefox 对WebRTC支持

    本文原创自 http://blog.csdn.net/voipmaker  转载注明出处. firefox pc和android 最新版本号已经默认支持webrtc, 同一时候,firefox在支持V ...

  3. 如何优雅的研究 RGSS3 (七) 加入LOGO屏幕

    对于游戏 LOGO 屏幕. 首先设计 LOGO Scene类.我们知道,现场类 Scene_Base 子类. 让我们回顾一下现场的作品. 首先运行开始处理.其次是开始治疗.然后停止更新屏幕,最后,治疗 ...

  4. Office文档在线编辑的实现之一

    因为项目的关系,研究了一下Office的在线编辑功能,写出来共享一下. Office xp之后的版本支持通过webdav协议(http的扩展)直接编辑服务器上的文件. IIS(6.0)支持webdav ...

  5. 异步陷阱之IO

    异步陷阱之IO篇 很多教程和资料都强调流畅的用户体验需要异步来辅助,核心思想就是保证用户前端的交互永远有最高的优先级,让一切费时的逻辑通通放到后台,等到诸事完备,通知一下前端给个提示或者继续下一步.随 ...

  6. 用HTML和javascript(JS)计算触屏手机手指滑动方向的演示

    移动终端的流行,程序员希望通过HTML+JS完成触屏动作的识别.下面给出具体实现的例子,供大家参考. 将下面的代码复制并保存,用手机访问,现在的手机浏览器一般都支持触屏,针对本演示来讲就是支持三个js ...

  7. Android项目---LayoutParams

    LinearLayout.LayoutParams extends ViewGroup.MarginLayoutParams java.lang.Object    ↳ android.view.Vi ...

  8. QueryOver<T>

    NHibernate 数据查询之QueryOver<T>   一.限制运算符 Where:筛选序列中的项目WhereNot:反筛选序列中的项目 二.投影运算符 Select:创建部分序列的 ...

  9. 回车tab切换

    //event表示事件对象,keyCode表示键值,srcElement事件源 function changeCommand(){ //如果按下的是回车,并且不是提交按钮,不是重置按钮,则回车认为是t ...

  10. 在线试听功能(前端直接略过吧,适合javaEE后台开发的)

    应用场景:录音试听,MP3试听... 比如为客户提供录音功能时.客户希望录音完成试听录音,然后下载等功能.直接上代码:关键是取得录音的在服务器的地址,如:url='http://localhost:8 ...