2月26th

利用jQuery中的ajax实现代码分页

DIY前端设计我来说两句!

把分页封装到一个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 &#63;  
          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 = /^\+&#63;[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请求的时候是刷新你特定的部门,我一开始就在这里出了问题。其实在做分页的时候,给后台传值,只是当前页和每页的显示个数,其他没了,分页的按钮和下方的列表是分离的,不用去联系,这样能使问题简单。时间有限就这样了,仔细看代码就可以了。

本文出自:DIY博客园,链接:https://www.diybloghome.com/frontlogy/1081.html,转载请注明!