原生js顯示分頁效果

<!DOCTYPE html> 

<html> 

<head lang="en"> 

<meta charset="UTF-8"> 

<title>原生js分頁</title> 

 <style type="text/css"> 

 #pageNav { display: inline-block; }
 #pageNav a { display: inline-block; width: 30px; height: 30px; line-height: 30px; text-align: center; color: #000; margin-right: 10px; text-decoration: none; background: #fff; }
 #pageNav a.active, #pageNav a:hover { background: #2176FF; color: #fff; } 

 </style>
</head> 

<body> 

<div id="pageBox"> 

<div id="containet"> 

<ul id="pageMain"> 

 <li>這是內容標題 第1條</li> 

 <li>這是內容標題 第2條</li> 

<li>這是內容標題 第3條</li> 

<li>這是內容標題 第4條</li> 

<li>這是內容標題 第5條</li> 

<li>這是內容標題 第6條</li> 

</ul> 

</div> 

<span id="prev">上一頁</span> 

<ul id="pageNav"></ul> 

<span id="next">下一頁</span> 

</div> 

</body> 

</html> 

<script> 

 window.onload = function(){
 tabPage({ 

 pageMain : 'pageMain', 

pageNav : 'pageNav', 

pagePrev: 'prev', 

 pageNext: 'next', 

 curNum: 3, //每頁顯示的條數 

activeClass: 'active', //高光顯示的class 

 ini: 0 //初始化顯示的頁面 

});
function tabPage(tabPage){ 

 var pageMain = document.getElementById(tabPage.pageMain); //獲取內容列表 

var pageNav = document.getElementById(tabPage.pageNav); //獲取分頁 

var pagePrev = document.getElementById(tabPage.pagePrev); //上一頁 

var pageNext = document.getElementById(tabPage.pageNext); //下一頁 

var curNum = tabPage.curNum; //每頁顯示數 

var len = Math.ceil(pageMain.children.length / curNum); //計算總頁數 

var pageList = ''; //生成頁碼 

var iNum = 0; //當前的索引值index 

 for(var i = 0; i < len; i++){ 

 pageList+='<a href="javascript:;">'+ ( i + 1)+'</a>'; 

} 

 pageNav.innerHTML = pageList;
 pageNav.children[0].className = tabPage.activeClass; //頭一頁加高亮顯示 

for(var i = 0; i < pageNav.children.length; i++){ 

 pageNav.children[i].index = i; 

 pageNav.children[i].onclick = function(){ 

 for(var t = 0; t < pageNav.children.length; t++){ pageNav.children[t].className = ''; } 

 this.className = tabPage.activeClass; iNum = this.index; ini(iNum); 

 };

 }
//下一頁 

pageNext.onclick = function(){ 

 if(iNum == len - 1){ alert('已是最後一頁'); return false; }

else{ 

 for(var t = 0; t < pageNav.children.length; t++){ pageNav.children[t].className = ''; } 

 iNum++; 

 pageNav.children[iNum].className = tabPage.activeClass; 

 ini(iNum); 

 } 

 };
//上一頁 

pagePrev.onclick = function(){ 

 if(iNum == 0){ alert('當前是第一頁'); return false; }

else{ 

 for(var t = 0; t < pageNav.children.length; t++){ pageNav.children[t].className = ''; } 

iNum--; 

 pageNav.children[iNum].className = tabPage.activeClass; 

ini(iNum); 

} 

 };
 function ini(iNum){ 

 for(var i = 0; i < pageMain.children.length; i++){ pageMain.children[i].style.display = 'none'; }
 for(var i = 0; i < curNum; i++){ 

 if(pageMain.children[(iNum * curNum + i)] == undefined){ continue; } 

 pageMain.children[(iNum * curNum + i)].style.display = 'block'; } 

 }
 ini(iNum);
 } 

}; 

</script>

// <![CDATA[ window.onload = function(){ tabPage({ pageMain : 'pageMain', pageNav : 'pageNav', pagePrev: 'prev', pageNext: 'next', curNum: 3, //每頁顯示的條數 activeClass: 'active', //高光顯示的class ini: 0 //初始化顯示的頁面 }); function tabPage(tabPage){ var pageMain = document.getElementById(tabPage.pageMain); //獲取內容列表 var pageNav = document.getElementById(tabPage.pageNav); //獲取分頁 var pagePrev = document.getElementById(tabPage.pagePrev); //上一頁 var pageNext = document.getElementById(tabPage.pageNext); //下一頁 var curNum = tabPage.curNum; //每頁顯示數 var len = Math.ceil(pageMain.children.length / curNum); //計算總頁數 var pageList = ''; //生成頁碼 var iNum = 0; //當前的索引值index for(var i = 0; i < len; i++){ pageList+='<a href="javascript:;">'+ ( i + 1)+'</a>'; } pageNav.innerHTML = pageList; pageNav.children[0].className = tabPage.activeClass; //頭一頁加高亮顯示 for(var i = 0; i < pageNav.children.length; i++){ pageNav.children[i].index = i; pageNav.children[i].onclick = function(){ for(var t = 0; t < pageNav.children.length; t++){ pageNav.children[t].className = ''; } this.className = tabPage.activeClass; iNum = this.index; ini(iNum); }; } //下一頁 pageNext.onclick = function(){ if(iNum == len - 1){ alert('已是最後一頁'); return false; }else{ for(var t = 0; t < pageNav.children.length; t++){ pageNav.children[t].className = ''; } iNum++; pageNav.children[iNum].className = tabPage.activeClass; ini(iNum); } }; //上一頁 pagePrev.onclick = function(){ if(iNum == 0){ alert('當前是第一頁'); return false; }else{ for(var t = 0; t < pageNav.children.length; t++){ pageNav.children[t].className = ''; } iNum--; pageNav.children[iNum].className = tabPage.activeClass; ini(iNum); } }; function ini(iNum){ for(var i = 0; i < pageMain.children.length; i++){ pageMain.children[i].style.display = 'none'; } for(var i = 0; i < curNum; i++){ if(pageMain.children[(iNum * curNum + i)] == undefined){ continue; } pageMain.children[(iNum * curNum + i)].style.display = 'block'; } } ini(iNum); } }; // ]]>
相關文章
相關標籤/搜索