利用jQuery中的ajax分頁實(shí)現(xiàn)代碼
本文實(shí)例講解了用jQuery中的ajax分頁相關(guān)代碼,分享給大家供大家參考,具體內(nèi)容如下
把分頁封裝到一個(gè)jsp里,那么大家就可以通過include的方式引入分頁的頁面這里起名為page_ajax.jsp
本人封裝后,使用者需要在頁面中引入page_ajax.jsp,并且在查詢列表的時(shí)候,點(diǎn)擊按鈕,調(diào)用自定義的方法,如myFunction(),在這個(gè)方法里頭,調(diào)用自己拓展的jquer方法,$.pageAjax(url,functionName,showDIv);
這里的url是你要請(qǐng)求的ajax的url,functionName為你要得到回調(diào)數(shù)據(jù)后處理拼串給tbody動(dòng)態(tài)賦值的方法,而showDIv是你隱藏的div。
也就是這樣寫即可:
function pageAjax(){ var url="${ctx}/system/conProductInfo/listOfAjax.action"; $.pageAjax(url,"productMessageDiv","showList"); }
productMessageDiv:這個(gè)就是你預(yù)先隱藏的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="%">產(chǎn)品編碼</td> <td width="%">產(chǎn)品名稱</td> <td width="%">產(chǎn)品型號(hào)</td> <td width="%">產(chǎn)品品牌</td> <td width="%">產(chǎn)品分類</td> <td width="%">供應(yīng)商</td> <td width="%">產(chǎn)品規(guī)格</td> </tr> </thead> <tbody id="msgContent"> </tbody> </table> </div> </div>
showList這個(gè)就是你得到回調(diào)數(shù)據(jù)調(diào)用的方法:
function showList(data){ var list=data.list; var str; if(list==""||list==null){ str="<tr><td colspan=\"9\"><span class=\"tip\">系統(tǒng)無紀(jì)錄!</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'>產(chǎn)品名稱</option><option value='productCode'>產(chǎn)品編號(hào)</option>"); $("#msgContent").empty(); $("#msgContent").append(str); }
復(fù)雜點(diǎn)的東西在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('頁數(shù)請(qǐng)輸入正整數(shù)'); return; } if(parseInt(pointedPageNum) > parseInt($('#totalPage').html())){ alert('輸入頁數(shù)不得超過最大頁數(shù)'); 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){ //如果頁數(shù)比總頁數(shù)小,則下一頁和末頁能用 $("#nextPage").removeAttr("disabled"); $("#lastPage").removeAttr("disabled"); if($("#forwardPageNum").val() >1){ //如果頁數(shù)大于1,說明 1<頁數(shù)<總頁數(shù) 說明全部都可用 $("#firstPage").removeAttr("disabled"); $("#beforePage").removeAttr("disabled"); }else{ //在頁數(shù)比總頁數(shù)小的其他情況下,就只存在一種就是等于1 $("#firstPage").attr("disabled","disabled"); //當(dāng)?shù)扔? 的時(shí)候,首頁和上一頁不可用 $("#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]+"'>默認(rèn)條數(shù)</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請(qǐng)求的時(shí)候是刷新你特定的部門,我一開始就在這里出了問題。其實(shí)在做分頁的時(shí)候,給后臺(tái)傳值,只是當(dāng)前頁和每頁的顯示個(gè)數(shù),其他沒了,分頁的按鈕和下方的列表是分離的,不用去聯(lián)系,這樣能使問題簡(jiǎn)單。時(shí)間有限就這樣了,仔細(xì)看代碼就可以了。
想要了解更多內(nèi)容請(qǐng)參考專題:《jquery分頁功能操作》
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)jquery程序設(shè)計(jì)有所幫助。
- 用jQuery中的ajax分頁實(shí)現(xiàn)代碼
- JQuery+Ajax無刷新分頁的實(shí)例代碼
- JS+Ajax+Jquery實(shí)現(xiàn)頁面無刷新分頁以及分組 超強(qiáng)的實(shí)現(xiàn)
- 使用PHP+JQuery+Ajax分頁的實(shí)現(xiàn)
- 基于Jquery+Ajax+Json的高效分頁實(shí)現(xiàn)代碼
- 使用Jquery+Ajax+Json如何實(shí)現(xiàn)分頁顯示附JAVA+JQuery實(shí)現(xiàn)異步分頁
- JQuery+Ajax實(shí)現(xiàn)數(shù)據(jù)查詢、排序和分頁功能
- jQuery+Ajax+PHP+Mysql實(shí)現(xiàn)分頁顯示數(shù)據(jù)實(shí)例講解
- jQuery實(shí)現(xiàn)分頁功能(含ajax請(qǐng)求、后臺(tái)數(shù)據(jù)、附完整demo)
相關(guān)文章
基于jQuery排序及應(yīng)用實(shí)現(xiàn)Tab欄特效
這篇文章主要介紹了基于jQuery排序及應(yīng)用實(shí)現(xiàn)Tab欄特效,jquery是基于JavaScript語言寫出來的一個(gè)框架,它封裝JavaScript常用的功能代碼,提供一種簡(jiǎn)便的JavaScript設(shè)計(jì)模式,但實(shí)質(zhì)上還是js,所以JQuery也屬于網(wǎng)頁編程語言。下面更多內(nèi)容需要的小伙伴可以參考一下2022-03-03基于jQuery實(shí)現(xiàn)咖啡訂單管理簡(jiǎn)單應(yīng)用
這篇文章主要為大家詳細(xì)介紹了基于jQuery實(shí)現(xiàn)咖啡訂單管理的簡(jiǎn)單應(yīng)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02jQuery實(shí)現(xiàn)的鼠標(biāo)滑過彈出放大圖片特效
最近項(xiàng)目遇到個(gè)需求,需要的效果是,鼠標(biāo)移到縮略圖上會(huì)顯示該圖的大圖,并且大圖跟隨鼠標(biāo)移動(dòng);或是移動(dòng)到提示文字上,也可以顯示圖片。經(jīng)過一番思索,用下面的方法實(shí)現(xiàn)了本效果,這里分享給大家。2016-01-01jQuery插件FusionCharts實(shí)現(xiàn)的3D帕累托圖效果示例【附demo源碼】
這篇文章主要介紹了jQuery插件FusionCharts實(shí)現(xiàn)的3D帕累托圖效果,結(jié)合實(shí)例形式分析了jQuery使用FusionCharts載入xml數(shù)據(jù)繪制3D帕累托圖的相關(guān)實(shí)現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03jQuery中對(duì)節(jié)點(diǎn)進(jìn)行操作的相關(guān)介紹
本篇文章小編將為大家介紹,在jQuery中對(duì)節(jié)點(diǎn)進(jìn)行操作的解決辦法,有需要的朋友可以參考一下2013-04-04jQuery實(shí)現(xiàn) 注冊(cè)時(shí)選擇閱讀條款 左右移動(dòng)
本篇文章,小編將為大家介紹jQuery實(shí)現(xiàn) 注冊(cè)時(shí)選擇閱讀條款 左右移動(dòng),有需要的朋友可以參考一下2013-04-04jQuery實(shí)現(xiàn)復(fù)制到粘貼板功能
這篇文章主要為大家詳細(xì)介紹了jquery實(shí)現(xiàn)復(fù)制到粘貼板功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02jquery操作iframe實(shí)現(xiàn)父頁面和子頁面相互操作的九種情況
現(xiàn)實(shí)開發(fā)中難免會(huì)遇到子頁面、父頁面相互操作的情況,本文主要介紹了jquery操作iframe實(shí)現(xiàn)父頁面和子頁面相互操作的九種情況,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02