溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

純jquery如何實(shí)現(xiàn)分頁(yè)效果

發(fā)布時(shí)間:2020-10-22 14:47:39 來(lái)源:億速云 閱讀:132 作者:小新 欄目:web開(kāi)發(fā)

純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)看看效果圖:

純jquery如何實(shí)現(xiàn)分頁(yè)效果

感謝各位的閱讀!看完上述內(nèi)容,你們對(duì)純jquery如何實(shí)現(xiàn)分頁(yè)效果大概了解了嗎?希望文章內(nèi)容對(duì)大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI