利用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序列化form表單數(shù)據(jù)為JSON對(duì)象的實(shí)現(xiàn)方法
這篇文章主要介紹了jQuery序列化form表單數(shù)據(jù)為JSON對(duì)象的實(shí)現(xiàn)方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09
用JQuery實(shí)現(xiàn)全選與取消的兩種簡(jiǎn)單方法
本篇文章主要是對(duì)JQuery實(shí)現(xiàn)全選與取消的兩種簡(jiǎn)單方法進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-02-02
jQuery中$.grep() 過濾函數(shù) 數(shù)組過濾
這篇文章主要介紹了jQuery中$.grep() 過濾函數(shù) 數(shù)組過濾的相關(guān)資料,需非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11
基于jQuery+Cookie實(shí)現(xiàn)的防止刷新的在線考試倒計(jì)時(shí)
這篇文章主要介紹了基于jQuery+Cookie實(shí)現(xiàn)的防止刷新的在線考試倒計(jì)時(shí)的方法和示例,有需要的小伙伴可以參考下2015-06-06
jquery+ajax+C#實(shí)現(xiàn)無刷新操作數(shù)據(jù)庫數(shù)據(jù)的簡(jiǎn)單實(shí)例
本篇文章主要是對(duì)jquery+ajax+C#實(shí)現(xiàn)無刷新操作數(shù)據(jù)庫數(shù)據(jù)的簡(jiǎn)單實(shí)例進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-02-02
jQuery+C#實(shí)現(xiàn)參數(shù)RSA加密傳輸功能【附j(luò)sencrypt.js下載】
這篇文章主要介紹了jQuery+C#實(shí)現(xiàn)參數(shù)RSA加密傳輸功能,結(jié)合具體實(shí)例形式分析了js使用jsencrypt.js插件前端字符數(shù)據(jù)處理傳輸及C#后臺(tái)數(shù)據(jù)轉(zhuǎn)換與RSA加密相關(guān)操作技巧,并附帶jsencrypt.js供讀者下載參考使用,需要的朋友可以參考下2017-06-06
JQuery為textarea添加maxlength屬性的代碼
textarea默認(rèn)不支持maxlength屬性。所以通過jquery實(shí)現(xiàn)下。具體的看代碼。2010-04-04

