您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關如何在PHP中利用Ajax實現一個無刷新分頁功能,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
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>
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
<?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" bordercolor="#666">'; echo '<caption><h2>華強電子網資訊</h2></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),請參考文章 《PHP的PDO常用類庫實例分析》,附有使用方法。
程序效果圖:
下圖標注的是注意關注的地方
這樣,Ajax 無刷新分頁就完成了。程序中還有一個 ajaxPage.class.php 沒有說明,其實,這個 ajaxPage 類庫的使用方法和一般的分頁類庫是一樣的。
即:$page = new ajaxPage(記錄總數, 每頁顯示數);
關于如何在PHP中利用Ajax實現一個無刷新分頁功能就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。