利用jQuery中的ajax分页实现代码
作者:bea
本文实例讲解了用jQuery中的ajax分页相关代码,分享给大家供大家参考,具体内容如下 把分页封装到一个jsp里,那么大家就可以通过include的方式引入分页的页面这里起名为page_ajax.jsp 本人封装后,使用者需要在页面中引入page_ajax.jsp,并且在查询列表的时候,点击按钮,调用自定义的方法,如myFunction(),在这个方法里头,调用自己拓展的jquer方法,$.pageAjax(url,functionName,showDIv); 这里的url
本文实例讲解了用jQuery中的ajax分页相关代码,分享给大家供大家参考,具体内容如下
把分页封装到一个jsp里,那么大家就可以通过include的方式引入分页的页面这里起名为page_ajax.jsp 本人封装后,使用者需要在页面中引入page_ajax.jsp,并且在查询列表的时候,点击按钮,调用自定义的方法,如myFunction(),在这个方法里头,调用自己拓展的jquer方法,$.pageAjax(url,functionName,showDIv); 这里的url是你要请求的ajax的url,functionName为你要得到回调数据后处理拼串给tbody动态赋值的方法,而showDIv是你隐藏的div。 也就是这样写即可:
function pageAjax(){
var url="${ctx}/system/conProductInfo/listOfAjax.action";
$.pageAjax(url,"productMessageDiv","showList");
}
productMessageDiv:这个就是你预先隐藏的div如下:
<div style="display: none;">
<div id="productMessageDiv" class="showParentDiv" style="width:950px;height:400px">
<div id="showProductListMsg">
<div class="grayBg">
<div id="toolbarScroll">
<span>
<input type="button" value=" 确定 " onclick="submitProductMessage();"/>
<input type="button" value=" 取消 " onclick="closeProduct();"/>
<input type="button" value=" 查询 " onclick="selectProduct();" />
<input id="value" name="value" type="text" class="width_132"/>
<select id="key" name="key" class="width_115">
</select>
</span>
</div>
<div class="page" id="page">
<jsp:include page="/portal/common/page/page_ajax.jsp"/>
</div>
<div class="clearFloat"></div>
</div>
<div class="scrollInfo">
<div class="tableInfo" style="overflow-y:scroll; height:365px;">
<table id="dragTable" border="0" cellpadding="0" cellspacing="0" id="listTable">
<thead>
<tr>
<td width="4%">
<input type="checkbox" id="selectallCheckBox" onclick="selectListall();"/>
</td>
<td width="%">产品编码</td>
<td width="%">产品名称</td>
<td width="%">产品型号</td>
<td width="%">产品品牌</td>
<td width="%">产品分类</td>
<td width="%">供应商</td>
<td width="%">产品规格</td>
</tr>
</thead>
<tbody id="msgContent">
</tbody>
</table>
</div>
</div>
showList这个就是你得到回调数据调用的方法:
function showList(data){
var list=data.list;
var str;
if(list==""||list==null){
str="<tr><td colspan="9"><span class="tip">系统无纪录!</span></td></tr>";
}else{
for(var i=0;i<list.length;i++){
str=str+" <tr id="contentTr"+i+""><td><input name="selectIds" type="checkbox" value=""+list[i].id+""/></td><td>"+list[i].productCode+"</td><td>"+list[i].productName+"</td><td>"+list[i].productType+"</td><td>"+list[i].brandName+"</td><td>"+list[i].typeName+"</td><td>"+list[i].companyShortname+"</td><td>"+list[i].productCode+"</td></tr>";
}
}
if($('#key').val()==""||$('#key').val()==null)$('#key').append("<option value='productName'>产品名称</option><option value='productCode'>产品编号</option>");
$("#msgContent").empty();
$("#msgContent").append(str);
}
复杂点的东西在page_ajax.jsp里头
var ajaxUrl;
var showDivName;
var ajaxFunctionName;
jQuery.extend({
pageAjax: function(url,div,functionName){
ajaxUrl=url;
showDivName=div;
ajaxFunctionName=functionName;
$.ajax({
url:url,
data:{"pageRequest.page":$('#pagePage').val(),"pageRequest.rows":$('#pageRows').val()},
dataType: "json",
success: function(data){
eval(functionName+"(data)");
$.changePageAjax(data);
showWin(div);
}
});
},
pageAjaxOfParam: function(url,div,functionName,key,value){
$.ajax({
url:url,
data:{"pageRequest.page":$('#pagePage').val(),"pageRequest.rows":$('#pageRows').val(),"key":key,"value":value},
dataType: "json",
success: function(data){
eval(functionName+"(data)");
$.changePageAjax(data);
showWin(div);
}
});
}
,
changePageAjax: function(data) {
var totalCount = data.totalCount;
changeDefaultRows(data);
var pageCount = totalCount % parseInt($("#pageRows").val())== 0 ?
parseInt(totalCount/parseInt($("#pageRows").val())):
parseInt(totalCount/parseInt($("#pageRows").val()))+1;
$("#totalPage").html(pageCount+'');
$("#totalCount").html(totalCount+'');
changeButton(pageCount);
}
});
function changePage(pageTitle) {
if(pageTitle == "previous"){
$('#pagePage').val(parseInt($('#pagePage').val()) - 1);
}else if(pageTitle == "next"){
$('#pagePage').val(parseInt($('#pagePage').val()) + 1);
}else if(pageTitle == "first"){
$('#pagePage').val(1);
}else if(pageTitle == "last"){
var totalCount = parseInt($('#totalCount').html());
$('#pagePage').val(parseInt((totalCount - 1) / parseInt($('#pageRows').val()) + '') + 1);
}
go();
}
function goToPointedPage(){
var pointedPageNum = $('#forwardPageNum').val();
var patrn = /^+?[1-9][0-9]*$/;
if(!patrn.exec(pointedPageNum)){
alert('页数请输入正整数');
return;
}
if(parseInt(pointedPageNum) > parseInt($('#totalPage').html())){
alert('输入页数不得超过最大页数');
return;
}
$('#pagePage').val(parseInt(pointedPageNum));
go();
}
function changeButton(pageCount){
$('#forwardPageNum').val($('#pagePage').val());
if(pageCount == 1){
$("#beforePage").attr("disabled","disabled");
$("#firstPage").attr("disabled","disabled");
$("#nextPage").attr("disabled","disabled");
$("#lastPage").attr("disabled","disabled");
}else if($("#forwardPageNum").val() < pageCount){ //如果页数比总页数小,则下一页和末页能用
$("#nextPage").removeAttr("disabled");
$("#lastPage").removeAttr("disabled");
if($("#forwardPageNum").val() >1){ //如果页数大于1,说明 1<页数<总页数 说明全部都可用
$("#firstPage").removeAttr("disabled");
$("#beforePage").removeAttr("disabled");
}else{ //在页数比总页数小的其他情况下,就只存在一种就是等于1
$("#firstPage").attr("disabled","disabled"); //当等于1 的时候,首页和上一页不可用
$("#beforePage").attr("disabled","disabled");
}
} else{
$("#beforePage").removeAttr("disabled");
$("#firstPage").removeAttr("disabled");
$("#nextPage").attr("disabled","disabled");
$("#lastPage").attr("disabled","disabled");
}
}
function changeDefaultRows(data){
if($("#pageRows").val()==null||$("#pageRows").val()==""){
$("#pageRows").empty();
$("#pageRows").append("<option value='"+data.pAGESIZES[0]+"'>默认条数</option><option value='"+data.pAGESIZES[1]+"'>"+data.pAGESIZES[1]+"</option><option value='"+data.pAGESIZES[2]+"'>"+data.pAGESIZES[2]+"</option>");
}
}
function changeRows(){
$('#pagePage').val(1);
go();
}
function go(){
$.pageAjax(ajaxUrl,showDivName,ajaxFunctionName);
}
function clearPageInfo(){
$("#pagePage").val('1');
}
$(function(){
$("body").keydown(function(event){
if(event.keyCode == 13){
goToPointedPage();
}
});
});
</script>
<div class="toolbarScroll">
<s:hidden name="pageRequest.page" id="pagePage"/>
<input id="firstPage" value=" 首页 " type="button" onclick="changePage('first')"/>
<input id="beforePage" value=" 上一页 " type="button" onclick="changePage('previous')"/>
<input size="6" maxlength="3" id="forwardPageNum" class="formStylePage" onblur="goToPointedPage()" value="" type="text" style="text-align: center;"/>/
<span class="currentPage" id="totalPage">
</span>
<input id="nextPage" value=" 下一页 " type="button" onclick="changePage('next')"/>
<input id="lastPage" value=" 末页 " type="button" onclick="changePage('last')"/>
共<span id="totalCount"></span>条
<span>
<select id="pageRows" name="pageRequest.rows" onchange="changeRows()"></select>
</span>
</div>
要明白ajax请求的时候是刷新你特定的部门,我一开始就在这里出了问题。其实在做分页的时候,给后台传值,只是当前页和每页的显示个数,其他没了,分页的按钮和下方的列表是分离的,不用去联系,这样能使问题简单。时间有限就这样了,仔细看代码就可以了。
想要了解更多内容请参考专题:《jquery分页功能操作》
以上就是本文的全部内容,希望对大家学习jquery程序设计有所帮助。
有用 | 无用
把分页封装到一个jsp里,那么大家就可以通过include的方式引入分页的页面这里起名为page_ajax.jsp 本人封装后,使用者需要在页面中引入page_ajax.jsp,并且在查询列表的时候,点击按钮,调用自定义的方法,如myFunction(),在这个方法里头,调用自己拓展的jquer方法,$.pageAjax(url,functionName,showDIv); 这里的url是你要请求的ajax的url,functionName为你要得到回调数据后处理拼串给tbody动态赋值的方法,而showDIv是你隐藏的div。 也就是这样写即可:
function pageAjax(){
var url="${ctx}/system/conProductInfo/listOfAjax.action";
$.pageAjax(url,"productMessageDiv","showList");
}
productMessageDiv:这个就是你预先隐藏的div如下:
<div style="display: none;">
<div id="productMessageDiv" class="showParentDiv" style="width:950px;height:400px">
<div id="showProductListMsg">
<div class="grayBg">
<div id="toolbarScroll">
<span>
<input type="button" value=" 确定 " onclick="submitProductMessage();"/>
<input type="button" value=" 取消 " onclick="closeProduct();"/>
<input type="button" value=" 查询 " onclick="selectProduct();" />
<input id="value" name="value" type="text" class="width_132"/>
<select id="key" name="key" class="width_115">
</select>
</span>
</div>
<div class="page" id="page">
<jsp:include page="/portal/common/page/page_ajax.jsp"/>
</div>
<div class="clearFloat"></div>
</div>
<div class="scrollInfo">
<div class="tableInfo" style="overflow-y:scroll; height:365px;">
<table id="dragTable" border="0" cellpadding="0" cellspacing="0" id="listTable">
<thead>
<tr>
<td width="4%">
<input type="checkbox" id="selectallCheckBox" onclick="selectListall();"/>
</td>
<td width="%">产品编码</td>
<td width="%">产品名称</td>
<td width="%">产品型号</td>
<td width="%">产品品牌</td>
<td width="%">产品分类</td>
<td width="%">供应商</td>
<td width="%">产品规格</td>
</tr>
</thead>
<tbody id="msgContent">
</tbody>
</table>
</div>
</div>
showList这个就是你得到回调数据调用的方法:
function showList(data){
var list=data.list;
var str;
if(list==""||list==null){
str="<tr><td colspan="9"><span class="tip">系统无纪录!</span></td></tr>";
}else{
for(var i=0;i<list.length;i++){
str=str+" <tr id="contentTr"+i+""><td><input name="selectIds" type="checkbox" value=""+list[i].id+""/></td><td>"+list[i].productCode+"</td><td>"+list[i].productName+"</td><td>"+list[i].productType+"</td><td>"+list[i].brandName+"</td><td>"+list[i].typeName+"</td><td>"+list[i].companyShortname+"</td><td>"+list[i].productCode+"</td></tr>";
}
}
if($('#key').val()==""||$('#key').val()==null)$('#key').append("<option value='productName'>产品名称</option><option value='productCode'>产品编号</option>");
$("#msgContent").empty();
$("#msgContent").append(str);
}
复杂点的东西在page_ajax.jsp里头
var ajaxUrl;
var showDivName;
var ajaxFunctionName;
jQuery.extend({
pageAjax: function(url,div,functionName){
ajaxUrl=url;
showDivName=div;
ajaxFunctionName=functionName;
$.ajax({
url:url,
data:{"pageRequest.page":$('#pagePage').val(),"pageRequest.rows":$('#pageRows').val()},
dataType: "json",
success: function(data){
eval(functionName+"(data)");
$.changePageAjax(data);
showWin(div);
}
});
},
pageAjaxOfParam: function(url,div,functionName,key,value){
$.ajax({
url:url,
data:{"pageRequest.page":$('#pagePage').val(),"pageRequest.rows":$('#pageRows').val(),"key":key,"value":value},
dataType: "json",
success: function(data){
eval(functionName+"(data)");
$.changePageAjax(data);
showWin(div);
}
});
}
,
changePageAjax: function(data) {
var totalCount = data.totalCount;
changeDefaultRows(data);
var pageCount = totalCount % parseInt($("#pageRows").val())== 0 ?
parseInt(totalCount/parseInt($("#pageRows").val())):
parseInt(totalCount/parseInt($("#pageRows").val()))+1;
$("#totalPage").html(pageCount+'');
$("#totalCount").html(totalCount+'');
changeButton(pageCount);
}
});
function changePage(pageTitle) {
if(pageTitle == "previous"){
$('#pagePage').val(parseInt($('#pagePage').val()) - 1);
}else if(pageTitle == "next"){
$('#pagePage').val(parseInt($('#pagePage').val()) + 1);
}else if(pageTitle == "first"){
$('#pagePage').val(1);
}else if(pageTitle == "last"){
var totalCount = parseInt($('#totalCount').html());
$('#pagePage').val(parseInt((totalCount - 1) / parseInt($('#pageRows').val()) + '') + 1);
}
go();
}
function goToPointedPage(){
var pointedPageNum = $('#forwardPageNum').val();
var patrn = /^+?[1-9][0-9]*$/;
if(!patrn.exec(pointedPageNum)){
alert('页数请输入正整数');
return;
}
if(parseInt(pointedPageNum) > parseInt($('#totalPage').html())){
alert('输入页数不得超过最大页数');
return;
}
$('#pagePage').val(parseInt(pointedPageNum));
go();
}
function changeButton(pageCount){
$('#forwardPageNum').val($('#pagePage').val());
if(pageCount == 1){
$("#beforePage").attr("disabled","disabled");
$("#firstPage").attr("disabled","disabled");
$("#nextPage").attr("disabled","disabled");
$("#lastPage").attr("disabled","disabled");
}else if($("#forwardPageNum").val() < pageCount){ //如果页数比总页数小,则下一页和末页能用
$("#nextPage").removeAttr("disabled");
$("#lastPage").removeAttr("disabled");
if($("#forwardPageNum").val() >1){ //如果页数大于1,说明 1<页数<总页数 说明全部都可用
$("#firstPage").removeAttr("disabled");
$("#beforePage").removeAttr("disabled");
}else{ //在页数比总页数小的其他情况下,就只存在一种就是等于1
$("#firstPage").attr("disabled","disabled"); //当等于1 的时候,首页和上一页不可用
$("#beforePage").attr("disabled","disabled");
}
} else{
$("#beforePage").removeAttr("disabled");
$("#firstPage").removeAttr("disabled");
$("#nextPage").attr("disabled","disabled");
$("#lastPage").attr("disabled","disabled");
}
}
function changeDefaultRows(data){
if($("#pageRows").val()==null||$("#pageRows").val()==""){
$("#pageRows").empty();
$("#pageRows").append("<option value='"+data.pAGESIZES[0]+"'>默认条数</option><option value='"+data.pAGESIZES[1]+"'>"+data.pAGESIZES[1]+"</option><option value='"+data.pAGESIZES[2]+"'>"+data.pAGESIZES[2]+"</option>");
}
}
function changeRows(){
$('#pagePage').val(1);
go();
}
function go(){
$.pageAjax(ajaxUrl,showDivName,ajaxFunctionName);
}
function clearPageInfo(){
$("#pagePage").val('1');
}
$(function(){
$("body").keydown(function(event){
if(event.keyCode == 13){
goToPointedPage();
}
});
});
</script>
<div class="toolbarScroll">
<s:hidden name="pageRequest.page" id="pagePage"/>
<input id="firstPage" value=" 首页 " type="button" onclick="changePage('first')"/>
<input id="beforePage" value=" 上一页 " type="button" onclick="changePage('previous')"/>
<input size="6" maxlength="3" id="forwardPageNum" class="formStylePage" onblur="goToPointedPage()" value="" type="text" style="text-align: center;"/>/
<span class="currentPage" id="totalPage">
</span>
<input id="nextPage" value=" 下一页 " type="button" onclick="changePage('next')"/>
<input id="lastPage" value=" 末页 " type="button" onclick="changePage('last')"/>
共<span id="totalCount"></span>条
<span>
<select id="pageRows" name="pageRequest.rows" onchange="changeRows()"></select>
</span>
</div>
要明白ajax请求的时候是刷新你特定的部门,我一开始就在这里出了问题。其实在做分页的时候,给后台传值,只是当前页和每页的显示个数,其他没了,分页的按钮和下方的列表是分离的,不用去联系,这样能使问题简单。时间有限就这样了,仔细看代码就可以了。
想要了解更多内容请参考专题:《jquery分页功能操作》
以上就是本文的全部内容,希望对大家学习jquery程序设计有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- js去字符串前后空格的实现方法
- js判断鼠标位置是否在某个div中的方法
- 超实用的JavaScript表单代码段
- 理解javascript中Map代替循环
- JS实现随页面滚动显示/隐藏窗口固定位置元素
- 学习使用jquery iScroll.js移动端滚动条插件
- AngularJS整合Springmvc、Spring、Mybatis搭建开发环境
- jQuery iScroll.js 移动端滚动条美化插件
- JavaScript 正则表达式中global模式的特性
- javascript动态获取登录时间和在线时长
- 基于javascript实现动态时钟效果
- jQuery使用zTree插件实现树形菜单和异步加载
- 灵活的理解JavaScript中的this指向
- jQuery插件实现表格隔行变色及鼠标滑过高亮显示效果代码
- jQuery插件实现文字无缝向上滚动效果代码
- jQuery zTree加载树形菜单功能
- JavaScript实现搜索框的自动完成功能(一)
- jquery插件之文字间歇自动向上滚动效果代码
- jQuery插件ImageDrawer.js实现动态绘制图片动画(附源码下载)