js實(shí)現(xiàn)ajax分頁(yè)完整實(shí)例
本文實(shí)例講述了js實(shí)現(xiàn)ajax分頁(yè)的方法。分享給大家供大家參考,具體如下:
<!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)
//當(dāng)前所在的屏數(shù),如curPage=21,總頁(yè)數(shù)為50頁(yè)時(shí),屏數(shù)就是3(當(dāng)前是第幾屏)實(shí)際上是這種形式: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+ ' 頁(yè)數(shù)據(jù)'); //ajax get data
}
initPage(50,2,10,'demo');
// --></script>
</body>
</html>
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動(dòng)畫特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- 使用bootstrap-paginator.js 分頁(yè)來進(jìn)行ajax 異步分頁(yè)請(qǐng)求示例
- Javascript vue.js表格分頁(yè),ajax異步加載數(shù)據(jù)
- vue.js 表格分頁(yè)ajax 異步加載數(shù)據(jù)
- 使用Jquery+Ajax+Json如何實(shí)現(xiàn)分頁(yè)顯示附JAVA+JQuery實(shí)現(xiàn)異步分頁(yè)
- Jquery+Ajax+Json+存儲(chǔ)過程實(shí)現(xiàn)高效分頁(yè)
- 基于Jquery+Ajax+Json實(shí)現(xiàn)分頁(yè)顯示附效果圖
- asp.net中利用Jquery+Ajax+Json實(shí)現(xiàn)無刷新分頁(yè)的實(shí)例代碼
- javascript ajax 仿百度分頁(yè)函數(shù)
- 基于Jquery+Ajax+Json的高效分頁(yè)實(shí)現(xiàn)代碼
- 原生js+ajax分頁(yè)組件
相關(guān)文章
Ajax配合Spring實(shí)現(xiàn)文件上傳功能代碼
最近在開發(fā)一個(gè)可以上傳圖片到服務(wù)器的web表面頁(yè)面,下面給大家分享需求和實(shí)現(xiàn)思路,需要的的朋友參考下吧2017-05-05
關(guān)于ajax對(duì)象一些常用屬性、事件和方法大小寫比較常見的問題總結(jié)
最近比較空閑,于是抽個(gè)時(shí)間整理些關(guān)于ajax方法的東東。在項(xiàng)目中經(jīng)常發(fā)現(xiàn)ajax板塊好多問題都是屬性,方法,事件大小寫不區(qū)分問題,最終導(dǎo)致了程序運(yùn)行出現(xiàn)麻煩,下面給大家介紹關(guān)于ajax對(duì)象一些常用屬性、事件和方法大小寫比較常見的問題總結(jié)2015-10-10
利用promise及參數(shù)解構(gòu)封裝ajax請(qǐng)求的方法
這篇文章主要介紹了利用promise及參數(shù)解構(gòu)封裝ajax請(qǐng)求的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
使用AJAX(包含正則表達(dá)式)驗(yàn)證用戶登錄的步驟
這篇文章主要介紹了使用AJAX(包含正則表達(dá)式)驗(yàn)證用戶登錄的步驟,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10
AJAX中同時(shí)發(fā)送多個(gè)請(qǐng)求XMLHttpRequest對(duì)象處理方法
AJAX中同時(shí)發(fā)送多個(gè)請(qǐng)求XMLHttpRequest對(duì)象處理方法...2007-04-04
判斷請(qǐng)求頭中是否含有某屬性來判斷是否是ajax請(qǐng)求
本文為大家介紹下如何判斷請(qǐng)求頭中是否含有某屬性來判斷是否時(shí)ajax請(qǐng)求,具體示例如下2014-01-01
Ajax動(dòng)態(tài)為下拉列表添加數(shù)據(jù)的實(shí)現(xiàn)方法
這篇文章主要介紹了Ajax動(dòng)態(tài)為下拉列表添加數(shù)據(jù)的實(shí)現(xiàn)方法,需要的朋友可以參考下2017-01-01

