当前位置:Gxlcms > JavaScript > 利用jQuery中的ajax分页实现代码_jquery

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

时间:2021-07-01 10:21:17 帮助过:7人阅读

本文实例讲解了用jQuery中的ajax分页相关代码,分享给大家供大家参考,具体内容如下

把分页封装到一个jsp里,那么大家就可以通过include的方式引入分页的页面这里起名为page_ajax.jsp
本人封装后,使用者需要在页面中引入page_ajax.jsp,并且在查询列表的时候,点击按钮,调用自定义的方法,如myFunction(),在这个方法里头,调用自己拓展的jquer方法,$.pageAjax(url,functionName,showDIv);
这里的url是你要请求的ajax的url,functionName为你要得到回调数据后处理拼串给tbody动态赋值的方法,而showDIv是你隐藏的div。
也就是这样写即可:

productMessageDiv:这个就是你预先隐藏的div如下:

  1. <div style="display: none;">
  2. <div id="productMessageDiv" class="showParentDiv" style="width:950px;height:400px">
  3. <div id="showProductListMsg">
  4. <div class="grayBg">
  5. <div id="toolbarScroll">
  6. <span>
  7. <input type="button" value=" 确定 " onclick="submitProductMessage();">
  8. <input type="button" value=" 取消 " onclick="closeProduct();">
  9. <input type="button" value=" 查询 " onclick="selectProduct();">
  10. <input id="value" name="value" type="text" class="width_132">
  11. <select id="key" name="key" class="width_115">
  12. </select>
  13. </span>
  14. </div>
  15. <div class="page" id="page">
  16. <jsp:include page="/portal/common/page/page_ajax.jsp">
  17. </jsp:include></div>
  18. <div class="clearFloat"></div>
  19. </div>
  20. <div class="scrollInfo">
  21. <div class="tableInfo" style="overflow-y:scroll; height:365px;">
  22. <table id="dragTable" border="0" cellpadding="0" cellspacing="0">
  23. <thead>
  24. <tr>
  25. <td width="4%">
  26. <input type="checkbox" id="selectallCheckBox" onclick="selectListall();">
  27. </td>
  28. <td width="%">产品编码</td>
  29. <td width="%">产品名称</td>
  30. <td width="%">产品型号</td>
  31. <td width="%">产品品牌</td>
  32. <td width="%">产品分类</td>
  33. <td width="%">供应商</td>
  34. <td width="%">产品规格</td>
  35. </tr>
  36. </thead>
  37. <tbody id="msgContent">
  38. </tbody>
  39. </table>
  40. </div>
  41. </div> </div></div></div>

showList这个就是你得到回调数据调用的方法:

复杂点的东西在page_ajax.jsp里头

  1. var ajaxUrl;
  2. var showDivName;
  3. var ajaxFunctionName;
  4. jQuery.extend({
  5. pageAjax: function(url,div,functionName){
  6. ajaxUrl=url;
  7. showDivName=div;
  8. ajaxFunctionName=functionName;
  9. $.ajax({
  10. url:url,
  11. data:{"pageRequest.page":$('#pagePage').val(),"pageRequest.rows":$('#pageRows').val()},
  12. dataType: "json",
  13. success: function(data){
  14. eval(functionName+"(data)");
  15. $.changePageAjax(data);
  16. showWin(div);
  17. }
  18. });
  19. },
  20. pageAjaxOfParam: function(url,div,functionName,key,value){
  21. $.ajax({
  22. url:url,
  23. data:{"pageRequest.page":$('#pagePage').val(),"pageRequest.rows":$('#pageRows').val(),"key":key,"value":value},
  24. dataType: "json",
  25. success: function(data){
  26. eval(functionName+"(data)");
  27. $.changePageAjax(data);
  28. showWin(div);
  29. }
  30. });
  31. }
  32. ,
  33. changePageAjax: function(data) {
  34. var totalCount = data.totalCount;
  35. changeDefaultRows(data);
  36. var pageCount = totalCount % parseInt($("#pageRows").val())== 0 ?
  37. parseInt(totalCount/parseInt($("#pageRows").val())):
  38. parseInt(totalCount/parseInt($("#pageRows").val()))+1;
  39. $("#totalPage").html(pageCount+'');
  40. $("#totalCount").html(totalCount+'');
  41. changeButton(pageCount);
  42. }
  43. });
  44. function changePage(pageTitle) {
  45. if(pageTitle == "previous"){
  46. $('#pagePage').val(parseInt($('#pagePage').val()) - 1);
  47. }else if(pageTitle == "next"){
  48. $('#pagePage').val(parseInt($('#pagePage').val()) + 1);
  49. }else if(pageTitle == "first"){
  50. $('#pagePage').val(1);
  51. }else if(pageTitle == "last"){
  52. var totalCount = parseInt($('#totalCount').html());
  53. $('#pagePage').val(parseInt((totalCount - 1) / parseInt($('#pageRows').val()) + '') + 1);
  54. }
  55. go();
  56. }
  57. function goToPointedPage(){
  58. var pointedPageNum = $('#forwardPageNum').val();
  59. var patrn = /^\+?[1-9][0-9]*$/;
  60. if(!patrn.exec(pointedPageNum)){
  61. alert('页数请输入正整数');
  62. return;
  63. }
  64. if(parseInt(pointedPageNum) > parseInt($('#totalPage').html())){
  65. alert('输入页数不得超过最大页数');
  66. return;
  67. }
  68. $('#pagePage').val(parseInt(pointedPageNum));
  69. go();
  70. }
  71. function changeButton(pageCount){
  72. $('#forwardPageNum').val($('#pagePage').val());
  73. if(pageCount == 1){
  74. $("#beforePage").attr("disabled","disabled");
  75. $("#firstPage").attr("disabled","disabled");
  76. $("#nextPage").attr("disabled","disabled");
  77. $("#lastPage").attr("disabled","disabled");
  78. }else if($("#forwardPageNum").val() < pageCount){ //如果页数比总页数小,则下一页和末页能用
  79. $("#nextPage").removeAttr("disabled");
  80. $("#lastPage").removeAttr("disabled");
  81. if($("#forwardPageNum").val() >1){ //如果页数大于1,说明 1<页数<总页数 说明全部都可用
  82. $("#firstPage").removeAttr("disabled");
  83. $("#beforePage").removeAttr("disabled");
  84. }else{ //在页数比总页数小的其他情况下,就只存在一种就是等于1
  85. $("#firstPage").attr("disabled","disabled"); //当等于1 的时候,首页和上一页不可用
  86. $("#beforePage").attr("disabled","disabled");
  87. }
  88. } else{
  89. $("#beforePage").removeAttr("disabled");
  90. $("#firstPage").removeAttr("disabled");
  91. $("#nextPage").attr("disabled","disabled");
  92. $("#lastPage").attr("disabled","disabled");
  93. }
  94. }
  95. function changeDefaultRows(data){
  96. if($("#pageRows").val()==null||$("#pageRows").val()==""){
  97. $("#pageRows").empty();
  98. $("#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>");
  99. }
  100. }
  101. function changeRows(){
  102. $('#pagePage').val(1);
  103. go();
  104. }
  105. function go(){
  106. $.pageAjax(ajaxUrl,showDivName,ajaxFunctionName);
  107. }
  108. function clearPageInfo(){
  109. $("#pagePage").val('1');
  110. }
  111. $(function(){
  112. $("body").keydown(function(event){
  113. if(event.keyCode == 13){
  114. goToPointedPage();
  115. }
  116. });
  117. });
  118. <!-- script-->
  119. <div class="toolbarScroll">
  120. <s:hidden name="pageRequest.page" id="pagePage">
  121. <input id="firstPage" value=" 首页 " type="button" onclick="changePage('first')">
  122. <input id="beforePage" value=" 上一页 " type="button" onclick="changePage('previous')">
  123. <input size="6" maxlength="3" id="forwardPageNum" class="formStylePage" onblur="goToPointedPage()" value="" type="text" style="text-align: center;">/
  124. <span class="currentPage" id="totalPage">
  125. </span>
  126. <input id="nextPage" value=" 下一页 " type="button" onclick="changePage('next')">
  127. <input id="lastPage" value=" 末页 " type="button" onclick="changePage('last')">
  128. 共<span id="totalCount"></span>条
  129. <span>
  130. <select id="pageRows" name="pageRequest.rows" onchange="changeRows()"></select>
  131. </span>
  132. </s:hidden></div>

要明白ajax请求的时候是刷新你特定的部门,我一开始就在这里出了问题。其实在做分页的时候,给后台传值,只是当前页和每页的显示个数,其他没了,分页的按钮和下方的列表是分离的,不用去联系,这样能使问题简单。时间有限就这样了,仔细看代码就可以了。

想要了解更多内容请参考专题:《jquery分页功能操作》

以上就是本文的全部内容,希望对大家学习jquery程序设计有所帮助。

人气教程排行