1. 程式人生 > >Ajax實現無刷新分頁

Ajax實現無刷新分頁

modify ble nbsp 合取 -type article -c height 文件中

註:本文中使用到的一些類庫在前面文章都能找到源代碼,我會在文中指明鏈接所在,為了縮短文章篇幅,由此帶來的閱讀不便,敬請諒解。

本文講解 Ajax 實現無刷新分頁、實現原理、代碼展示、代碼下載。

這裏需要說明一些知識:

1、Ajax 無刷新頁面的好處:提供良好的客戶體驗,通過 Ajax 在後臺從數據庫中取得數據並展示,取締了等待加載頁面而出現的空白狀態;

2、那麽,Ajax 無刷新頁面是運行在動態頁面(.PHP)?還是靜態頁面(.html/.htm/.shtml)?答案是:靜態頁面;

3、實現原理:通過前端 JS 腳本程序與 Ajax 相結合取得從動態頁面返回的數據,並顯示。

好了,下面進行代碼講解:

既然,是運行在靜態頁面上,我們首先先創建一個靜態 HTML 頁面,index.html 的代碼清單如下。

index.html

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
<html>  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
<script type="text/javascript" src="js/ajax.js"></script> <!-- 載入 Ajax 類庫 -->  
<title>Ajax 實現無刷新頁面</title>  
<style type="text/css">  
    body {  
        font
-size:12px; } </style> </head> <body> <div id="fpage">數據加載中...</div> </body> </html>

代碼清單中,我們加載了一個 Ajax 類庫,在這個靜態頁面中,只會顯示一個“數據加載中....”,並沒有任何數據。這時,我們就需要一個 JS 腳本來實現通過 Ajax 從數據庫中獲取數據。JS 腳本如下:

<script type="text/javascript">  
    /** 
    * setPage(url) 根據 url 從 article.php 中獲取數據 
    * @param int pageNum 頁碼 
    * @return string 
    
*/ var cache=new Array(); // 緩存變量,當數據被訪問過之後放置在緩存中,加快訪問速度 function setPage(pageNum) { var fpage = document.getElementById(‘fpage‘); // 獲取 fpage 對象 // 如果緩存中存在數據,那麽直接從緩存中讀取;如果不存在數據,那麽就從數據庫中讀取,並把數據存入緩存 if (typeof(cache[pageNum])==‘undefined‘) { var ajax = Ajax(); ajax.get(‘article.php?page=‘+pageNum, function(data){ fpage.innerHTML = data; // fpage對象的內容是從 article.php 中取來的 cache[pageNum] = data; }) } else { fpage.innerHTML = cache[pageNum]; } } setPage(1); // 默認執行 </script>

仔細閱讀上面的代碼,您會發現下面現象:

1、setPage(pageNum) 是一個從數據庫中提取數據的 JS 函數接口;

2、Ajax 是通過 article.php 文件來獲取數據;

3、article.php?page=xx,這裏的 xx 就是所要取得的頁碼數據,

setPage(1):就是取得第1頁數據;

setPage(2):就是取得第2頁數據;

setPage(100):就是取得第100頁數據;

……

那麽,如何從 article.php 文件中取得數據呢?請看下面代碼清單。

article.php

<?php  
/** 
* $Id: article.php 
* author Lee. 
* Last modify $Date: 2012-01-21 16:53:05 $ 
*/  
require_once ‘./config.inc.php‘;  
$m = new Model();  
$page = new ajaxPage($m->total(‘article‘),20); // $m->total(‘article‘) 獲取 article 表的記錄數;10為每頁顯示十條  
$result = $m->fetchAll(‘article‘, ‘*‘, ‘‘, ‘‘, $page->limit); // 取出數據,^_^,很方便吧  
echo ‘<table align="center" border="1" width="1100" style="border-collapse:collapse;font-size:14px;" bordercolor="#666">‘;  
echo ‘<caption><h1>華強電子網資訊</h1></caption>‘;  
echo ‘<tr height="25"><th>ID</th><th>Title</th><th>Author</th><th>Source</th><th>Date</th></tr>‘;  
foreach ($result as $v) {  
    echo "<tr height=‘21‘><td align=‘center‘>{$v[‘id‘]}</td><td>{$v[‘title‘]}</td><td align=‘center‘>{$v[‘author‘]}</td><td align=‘center‘>{$v[‘source‘]}</td><td align=‘center‘>{$v[‘date‘]}</td></tr>";  
}  
echo ‘<tr><td align="right" colspan="5">‘.$page->fpage().‘</td></tr>‘;  
echo ‘</table>‘;  
?>  

article.php 中連接的數據是前面文章從華強電子網抓來的資訊數據,因為數據比較大,代碼打包下載中會附加 article.sql 文件,以便大家測試。

靜態頁面 index.html 上顯示的數據就是 article.php 文件中 echo 的代碼。

代碼文件中的 config.inc.php 文件主要就是定義一些常量,比如:數據庫用戶名、數據庫密碼、主機……,數據庫連接類庫(Db.class.php)和數據庫操作類庫(Model.class.php),請參考文章 http://blog.csdn.net/liruxing1715/article/details/7176671,附有使用方法。

程序效果圖:

下圖標註的是註意關註的地方。

技術分享

這樣,Ajax 無刷新分頁就完成了。程序中還有一個 ajaxPage.class.php 沒有說明,其實,這個 ajaxPage 類庫的使用方法和一般的分頁類庫是一樣的。

即:$page = new ajaxPage(記錄總數, 每頁顯示數); 源碼地址:http://pan.baidu.com/share/init?shareid=1456793845&uk=1997289381;

密碼:【3gqk】

Ajax實現無刷新分頁