js實現(xiàn)ajax分頁完整實例
本文實例講述了js實現(xiàn)ajax分頁的方法。分享給大家供大家參考,具體如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>Untitled Document</title>
</head>
<body>
<style type="text/css">
*{margin:0;padding:0}
.ajax_page{padding:1px 4px;border:1px solid #e60011;margin:0 2px;text-decoration:none;color:#666666;font-family:mingliu;font-size:11px;height:14px;line-height:14px;float:left;font-weight:bold;display:block;}
span.currentPage{padding:2px 4px;color:#666666;font-size:11px;height:14px;line-height:14px;float:left;display:block;font-weight:bold;font-family:mingliu}
</style>
<style type="text/css">
*{margin:0;padding:0}
.ajax_page{padding:1px 4px;border:1px solid #e60011;margin:0 2px;text-decoration:none;color:#666666;font-family:mingliu;font-size:11px;height:14px;line-height:14px;float:left;font-weight:bold;display:block;}
span.currentPage{padding:2px 4px;color:#666666;font-size:11px;height:14px;line-height:14px;float:left;display:block;font-weight:bold;font-family:mingliu}
</style>
<div id="demo" style="width:500px;margin:10px auto;"></div>
<script type="text/JavaScript">
<!--
function initPage(totalPages,curPage,middlePage,Container){
var htmlstr = '';
if(curPage > totalPages) {curPage = totalPages}
if(curPage < 0) {curPage = 1}
var curBigPage = Math.ceil(curPage/middlePage)
//當前所在的屏數(shù),如curPage=21,總頁數(shù)為50頁時,屏數(shù)就是3(當前是第幾屏)實際上是這種形式:Math.ceil(curPage*pageSize/pageSize*perPage)
var totalBigPage = Math.ceil(totalPages/middlePage); //總的屏數(shù)
if( totalPages < middlePage){
for(var i=1;i<totalPages+1;i++){
if(i == curPage){
htmlstr += '<span class="currentPage">' + i + '</span>';
}else{
htmlstr += '<a href="javascript:void(0)" mce_href="javascript:void(0)" onclick="initPage('+ totalPages+','+i+','+middlePage +',/''+ container+'/');getPageData('+ i+');return false" class="ajax_page">'+i +'</a>';
}
}
}else{
var curBigStart = (curBigPage-1)*middlePage + 1;
if(curBigPage == totalBigPage){
var curBigEnd = totalPages;
}else{
var curBigEnd = curBigPage * middlePage;
}
if(curBigPage != 1){ //前一屏
var preCurPage = curBigStart - middlePage;
htmlstr += '<a href="javascript:void(0)" mce_href="javascript:void(0)" onclick="initPage('+ totalPages+','+preCurPage+','+middlePage +',/''+ container+'/');getPageData('+ preCurPage +');return false" class="ajax_page">pre</a>';
}
for(var i=curBigStart;i<=curBigEnd;i++){
if(i == curPage){
htmlstr += '<span class="currentPage">' + i + '</span>';
}else{
htmlstr += '<a href="javascript:void(0)" mce_href="javascript:void(0)" onclick="initPage('+ totalPages+','+i+','+middlePage +',/''+ container+'/');getPageData('+ i +');return false" class="ajax_page">' + i + '</a>';
}
}
if(curBigPage != totalBigPage){ //后一屏
var nextCurPage = curBigStart + middlePage;
htmlstr += '<a href="javascript:void(0)" mce_href="javascript:void(0)" onclick="initPage('+ totalPages+','+nextCurPage+','+middlePage +',/''+ container+'/');getPageData('+ nextCurPage + ');return false" class="ajax_page">next</a>';
}
}
document.getElementById('demo').innerHTML = htmlstr
}
function getPageData(i){
alert('現(xiàn)在取第 '+i+ ' 頁數(shù)據(jù)'); //ajax get data
}
initPage(50,2,10,'demo');
// --></script>
</body>
</html>
更多關于JavaScript相關內(nèi)容感興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學運算用法總結(jié)》
希望本文所述對大家JavaScript程序設計有所幫助。
- 使用bootstrap-paginator.js 分頁來進行ajax 異步分頁請求示例
- Javascript vue.js表格分頁,ajax異步加載數(shù)據(jù)
- vue.js 表格分頁ajax 異步加載數(shù)據(jù)
- 使用Jquery+Ajax+Json如何實現(xiàn)分頁顯示附JAVA+JQuery實現(xiàn)異步分頁
- Jquery+Ajax+Json+存儲過程實現(xiàn)高效分頁
- 基于Jquery+Ajax+Json實現(xiàn)分頁顯示附效果圖
- asp.net中利用Jquery+Ajax+Json實現(xiàn)無刷新分頁的實例代碼
- javascript ajax 仿百度分頁函數(shù)
- 基于Jquery+Ajax+Json的高效分頁實現(xiàn)代碼
- 原生js+ajax分頁組件
相關文章
關于ajax對象一些常用屬性、事件和方法大小寫比較常見的問題總結(jié)
最近比較空閑,于是抽個時間整理些關于ajax方法的東東。在項目中經(jīng)常發(fā)現(xiàn)ajax板塊好多問題都是屬性,方法,事件大小寫不區(qū)分問題,最終導致了程序運行出現(xiàn)麻煩,下面給大家介紹關于ajax對象一些常用屬性、事件和方法大小寫比較常見的問題總結(jié)2015-10-10
利用promise及參數(shù)解構(gòu)封裝ajax請求的方法
這篇文章主要介紹了利用promise及參數(shù)解構(gòu)封裝ajax請求的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01
AJAX中同時發(fā)送多個請求XMLHttpRequest對象處理方法
AJAX中同時發(fā)送多個請求XMLHttpRequest對象處理方法...2007-04-04
Ajax動態(tài)為下拉列表添加數(shù)據(jù)的實現(xiàn)方法
這篇文章主要介紹了Ajax動態(tài)為下拉列表添加數(shù)據(jù)的實現(xiàn)方法,需要的朋友可以參考下2017-01-01

