以前在使用Asp.Net的時候用過GridView這個控件,這個控件自帶分頁的功能,雖然很丑,但是功能還是很強大的。這里呢,給大家展示一下更加給力的方式——利用AJAX無刷新直接從服務(wù)器獲取數(shù)據(jù)分頁。
一、實現(xiàn)過程
注意:一下的內(nèi)容都是在服務(wù)器內(nèi)使用的。
首先要在服務(wù)器的路徑下建立幾個文件,比如,page1.txt,page2.txt,page3.txt。
每個文件中放入數(shù)組,如下:
復(fù)制代碼 代碼如下:
[{user:'blue',pass:'123'},{user:'aaa',pass:'dsfaa'},{user:'Ares',pass:'12346'}]

圖一 頁面一的內(nèi)容
前臺HTML代碼:
!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=utf-8" />
title>AJAX實現(xiàn)分頁、/title>
script src="ajax.js">/script>
script>
window.onload=function ()
{
var oUl=document.getElementById('ul1');
var aBtn=document.getElementsByTagName('a');
var i=0;
for(i=0;iaBtn.length;i++)
{
//給每一個按鈕附一個初值索引
aBtn[i].index=i;
aBtn[i].onclick=function ()
{
//調(diào)用AJAX函數(shù)
ajax('page'+(this.index+1)+'.txt', function (str){
//獲得其中的數(shù)據(jù)
var aData=eval(str);
oUl.innerHTML='';
for(i=0;iaData.length;i++)
{
var oLi=document.createElement('li');
oLi.innerHTML='strong>'+aData[i].user+'/strong>i>'+aData[i].pass+'/i>';
oUl.appendChild(oLi);
}
});
};
}
};
/script>
/head>
body>
ul id="ul1">
/ul>
a href="javascript:;">1/a>
a href="javascript:;">2/a>
a href="javascript:;">3/a>
/body>
/html>
封裝的AJAX ,JavaScript代碼:
/*
AJAX封裝函數(shù)
url:系統(tǒng)要讀取文件的地址
fnSucc:一個函數(shù),文件取過來,加載完會調(diào)用
*/
function ajax(url, fnSucc, fnFaild)
{
//1.創(chuàng)建Ajax對象
var oAjax=null;
if(window.XMLHttpRequest)
{
oAjax=new XMLHttpRequest();
}
else
{
oAjax=new ActiveXObject("Microsoft.XMLHTTP");
}
//2.連接服務(wù)器
oAjax.open('GET', url, true);
//3.發(fā)送請求
oAjax.send();
//4.接收服務(wù)器的返回
oAjax.onreadystatechange=function ()
{
if(oAjax.readyState==4) //完成
{
if(oAjax.status==200) //成功
{
fnSucc(oAjax.responseText);
}
else
{
if(fnFaild)
fnFaild(oAjax.status);
}
}
};
}
最終實現(xiàn)效果:
圖二 展示效果
二、小結(jié)
AJAX這個還是要多多嘗試的,還要多多的練習(xí)。分頁是很好的想法,可以提高訪問的速度,很好的方法,以后還會更好的給大家?guī)硎斋@。
您可能感興趣的文章:- Javascript vue.js表格分頁,ajax異步加載數(shù)據(jù)
- vue.js 表格分頁ajax 異步加載數(shù)據(jù)
- php+ajax實現(xiàn)無刷新數(shù)據(jù)分頁的辦法
- jQuery+Ajax+PHP+Mysql實現(xiàn)分頁顯示數(shù)據(jù)實例講解
- JQuery+Ajax實現(xiàn)數(shù)據(jù)查詢、排序和分頁功能
- C#基于數(shù)據(jù)庫存儲過程的AJAX分頁實例
- Ajax讀取數(shù)據(jù)之分頁顯示篇實現(xiàn)代碼
- AspNetAjaxPager,Asp.Net通用無刷新Ajax分頁控件,支持多樣式多數(shù)據(jù)綁定
- xml分頁+ajax請求數(shù)據(jù)源+dom取結(jié)果實例代碼
- ajax實現(xiàn)數(shù)據(jù)分頁查詢