您好,登錄后才能下訂單哦!
純jquery如何實(shí)現(xiàn)分頁(yè)效果?這個(gè)問(wèn)題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見(jiàn)到的。希望通過(guò)這個(gè)問(wèn)題能讓你收獲頗深。下面是小編給大家?guī)?lái)的參考內(nèi)容,讓我們一起來(lái)看看吧!
我們?cè)谇岸隧?yè)面開(kāi)發(fā)過(guò)程中,如果一個(gè)頁(yè)面顯示的數(shù)據(jù)過(guò)多、頁(yè)面過(guò)長(zhǎng),會(huì)讓用戶的體驗(yàn)感下降。這個(gè)時(shí)候,我們就需要把數(shù)據(jù)分成好幾頁(yè)來(lái)顯示,也就是所謂的分頁(yè)。
下面我們就通過(guò)簡(jiǎn)單的代碼示例,為大家詳細(xì)介紹用純jquery實(shí)現(xiàn)一個(gè)前端超簡(jiǎn)單的分頁(yè)效果!
css代碼:
ul.pagination { display: inline-block; padding: 0; margin: 0; } ul.pagination li {display: inline;} ul.pagination li a { color: black; float: left; padding: 8px 16px; text-decoration: none; border: 1px solid blue; border-radius:3px; } .active{ background-color: #7FFFAA; }
html代碼:
<h3>最簡(jiǎn)單的分頁(yè)</h3> <ul class="pagination"></ul> <input type="hidden" id="currentPage" name="currentPage" value="1"></input> <input type="hidden" id="totalPage" value="54"></input>
js腳本文件
1、引用Jquery和分頁(yè)腳本
<script src="/js/jquery.min.js" type="text/javascript"></script> <script src="/js/jquery.PageBar.js" type="text/javascript"></script>
2、編寫(xiě)jquery.PageBar.js腳本
$().ready(function(){ var curPage =$("#currentPage").val(); var last =$("#totalPage").val(); var page =Math.ceil(curPage/10); //調(diào)用繪制分頁(yè)樣式函數(shù) draw(page,curPage); //綁定點(diǎn)擊頁(yè)碼事件 $(document).on("click",".pagination li a",function(){ var str =$(this).html(); if(!isNaN(str)){ //移除之前的active $(".pagination li a").removeClass("active"); $(this).attr("class","active"); $("#currentPage").val(str); } }); //綁定下一頁(yè)點(diǎn)擊事件 $(document).on("click","#nextPage",function(){ var num =$(".active").html(); var curPage =$("#currentPage").val(); var last =$("#totalPage").val(); var page =Math.ceil((parseInt(num))/10); if(num < page*10 && num != last){ //移除之前的active $(".pagination li a").removeClass("active"); $("#"+(parseInt(num)+1)+"").attr("class","active"); //$(".pagination li a[text="+(parseInt(num)+1)+"]").attr("class","active");//jQ1.6支持 $("#currentPage").val(parseInt(num)+1); }else if(num == page*10 && num != last){ //清空之前的數(shù)據(jù) $(".pagination").html(""); draw(page+1,(parseInt(num)+1)); } }) //綁定上一頁(yè)點(diǎn)擊事件 $(document).on("click","#previousPage",function(){ var num =$(".active").html(); var curPage =$("#currentPage").val(); var last =$("#totalPage").val(); var page =Math.ceil((parseInt(num))/10); if(num <= page*10 && num != (page-1)*10+1){ //移除之前的active $(".pagination li a").removeClass("active"); $("#"+(parseInt(num)-1)+"").attr("class","active"); //$(".pagination li a[text="+(parseInt(num)+1)+"]").attr("class","active");//jQ1.6支持 $("#currentPage").val(parseInt(num)-1); }else if(num == (page-1)*10+1 && num != 1){ //清空之前的數(shù)據(jù) $(".pagination").html(""); draw(page-1,(parseInt(num)-1)); } }) //繪制頁(yè)面分頁(yè)樣式 function draw(page,curPage){ //頁(yè)面中的當(dāng)前頁(yè) var page =page; //后臺(tái)傳過(guò)來(lái)的頁(yè)數(shù) var curPage = curPage; //后臺(tái)傳過(guò)來(lái)的總頁(yè)數(shù) var datas =$("#totalPage").val(); //每頁(yè)顯示多少條數(shù)據(jù) var pageSize =10; //在網(wǎng)頁(yè)中一共要分多少頁(yè) var totalPage = Math.floor((datas-1)/pageSize+1); var liStr ="<li><a id='previousPage' href='#'>上一頁(yè)</a></li>"; $("#currentPage").val(curPage); if(page <= totalPage){ if(datas <= 10){ for(i=1; i<=datas; i++){ //為當(dāng)前頁(yè)增加樣式 var active =""; if(i==curPage){ active=" class='active' "; } liStr +=" <li><a id="+i+" "+active+" href='#'>"+i+"</a></li>" } }else{ var start =pageSize*(page-1)+1; var end =page*pageSize; if(page == totalPage){ for(i=start; i<=datas; i++){ //為當(dāng)前頁(yè)增加樣式 var active =""; if(i==curPage){ active=" class='active' "; } liStr +=" <li><a id="+i+" "+active+" href='#'>"+i+"</a></li>" } }else{ for(i=start; i<=end; i++){ //為當(dāng)前頁(yè)增加樣式 var active =""; if(i==curPage){ active=" class='active' "; } liStr +=" <li><a id="+i+" "+active+" href='#'>"+i+"</a></li>" } } } } liStr +="<li><a id='nextPage' href='#'>下一頁(yè)</a></li>"; $(".pagination").append(liStr); } })
我們來(lái)看看效果圖:
感謝各位的閱讀!看完上述內(nèi)容,你們對(duì)純jquery如何實(shí)現(xiàn)分頁(yè)效果大概了解了嗎?希望文章內(nèi)容對(duì)大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。