PHP+Ajax實(shí)現(xiàn)無(wú)刷新分頁(yè)實(shí)例詳解(附demo源碼下載)
本文實(shí)例講述了PHP+Ajax實(shí)現(xiàn)無(wú)刷新分頁(yè)的方法。分享給大家供大家參考,具體如下:
注:這里使用到的一些類庫(kù)在前面文章都能找到源代碼,因此為了縮短文章篇幅,都指明鏈接所在。
本文講解內(nèi)容為: Ajax 實(shí)現(xiàn)無(wú)刷新分頁(yè)、實(shí)現(xiàn)原理、代碼展示、代碼下載。
這里需要說明一些知識(shí):
1、Ajax 無(wú)刷新頁(yè)面的好處:提供良好的客戶體驗(yàn),通過 Ajax 在后臺(tái)從數(shù)據(jù)庫(kù)中取得數(shù)據(jù)并展示,取締了等待加載頁(yè)面而出現(xiàn)的空白狀態(tài);
2、那么,Ajax 無(wú)刷新頁(yè)面是運(yùn)行在動(dòng)態(tài)頁(yè)面(.php)?還是靜態(tài)頁(yè)面(.html/.htm/.shtml)?答案是:靜態(tài)頁(yè)面;
3、實(shí)現(xiàn)原理:通過前端 JS 腳本程序與 Ajax 相結(jié)合取得從動(dòng)態(tài)頁(yè)面返回的數(shù)據(jù),并顯示。
好了,下面進(jìn)行代碼講解:
既然,是運(yùn)行在靜態(tài)頁(yè)面上,我們首先先創(chuàng)建一個(gè)靜態(tài) HTML 頁(yè)面,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 類庫(kù) --> <title>Ajax 實(shí)現(xiàn)無(wú)刷新頁(yè)面</title> <style type="text/css"> body { font-size:12px; } </style> </head> <body> <div id="fpage">數(shù)據(jù)加載中...</div> </body> </html>
代碼清單中,我們加載了一個(gè) Ajax 類庫(kù),這個(gè)類庫(kù)可以在 前面一篇《一個(gè)簡(jiǎn)單Ajax類庫(kù)及使用方法實(shí)例分析》中找到
在這個(gè)靜態(tài)頁(yè)面中,只會(huì)顯示一個(gè)“數(shù)據(jù)加載中....”,并沒有任何數(shù)據(jù)。這時(shí),我們就需要一個(gè) JS 腳本來實(shí)現(xiàn)通過 Ajax 從數(shù)據(jù)庫(kù)中獲取數(shù)據(jù)。JS 腳本如下:
<script type="text/javascript"> /** * setPage(url) 根據(jù) url 從 article.php 中獲取數(shù)據(jù) * @param int pageNum 頁(yè)碼 * @return string */ var cache=new Array(); // 緩存變量,當(dāng)數(shù)據(jù)被訪問過之后放置在緩存中,加快訪問速度 function setPage(pageNum) { var fpage = document.getElementById('fpage'); // 獲取 fpage 對(duì)象 // 如果緩存中存在數(shù)據(jù),那么直接從緩存中讀取;如果不存在數(shù)據(jù),那么就從數(shù)據(jù)庫(kù)中讀取,并把數(shù)據(jù)存入緩存 if (typeof(cache[pageNum])=='undefined') { var ajax = Ajax(); ajax.get('article.php?page='+pageNum, function(data){ fpage.innerHTML = data; // fpage對(duì)象的內(nèi)容是從 article.php 中取來的 cache[pageNum] = data; }) } else { fpage.innerHTML = cache[pageNum]; } } setPage(1); // 默認(rèn)執(zhí)行 </script>
仔細(xì)閱讀上面的代碼,您會(huì)發(fā)現(xiàn)下面現(xiàn)象:
1、setPage(pageNum) 是一個(gè)從數(shù)據(jù)庫(kù)中提取數(shù)據(jù)的 JS 函數(shù)接口;
2、Ajax 是通過 article.php 文件來獲取數(shù)據(jù);
3、article.php?page=xx,這里的 xx 就是所要取得的頁(yè)碼數(shù)據(jù),
setPage(1):就是取得第1頁(yè)數(shù)據(jù);
setPage(2):就是取得第2頁(yè)數(shù)據(jù);
setPage(100):就是取得第100頁(yè)數(shù)據(jù);
……
那么,如何從 article.php 文件中取得數(shù)據(jù)呢?請(qǐng)看下面代碼清單。
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 表的記錄數(shù);10為每頁(yè)顯示十條 $result = $m->fetchAll('article', '*', '', '', $page->limit); // 取出數(shù)據(jù),^_^,很方便吧 echo '<table align="center" border="1" width="1100" style="border-collapse:collapse;font-size:14px;" bordercolor="#666">'; echo '<caption><h1>華強(qiáng)電子網(wǎng)資訊</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 中連接的數(shù)據(jù)是前面文章從華強(qiáng)電子網(wǎng)抓來的資訊數(shù)據(jù),因?yàn)閿?shù)據(jù)比較大,代碼打包下載中會(huì)附加 article.sql 文件,以便大家測(cè)試。
靜態(tài)頁(yè)面 index.html 上顯示的數(shù)據(jù)就是 article.php 文件中 echo 的代碼。
代碼文件中的 config.inc.php 文件主要就是定義一些常量,比如:數(shù)據(jù)庫(kù)用戶名、數(shù)據(jù)庫(kù)密碼、主機(jī)……,數(shù)據(jù)庫(kù)連接類庫(kù)(Db.class.php)和數(shù)據(jù)庫(kù)操作類庫(kù)(Model.class.php),請(qǐng)參考文章 《PHP的PDO常用類庫(kù)實(shí)例分析》,附有使用方法。
程序效果圖:
下圖標(biāo)注的是注意關(guān)注的地方
這樣,Ajax 無(wú)刷新分頁(yè)就完成了。程序中還有一個(gè) ajaxPage.class.php 沒有說明,其實(shí),這個(gè) ajaxPage 類庫(kù)的使用方法和一般的分頁(yè)類庫(kù)是一樣的。
即:$page = new ajaxPage(記錄總數(shù), 每頁(yè)顯示數(shù));
具體細(xì)節(jié)請(qǐng)大家下載代碼閱讀即可。
完整實(shí)例代碼點(diǎn)擊此處本站下載。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP+ajax技巧與應(yīng)用小結(jié)》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語(yǔ)法入門教程》、《php操作office文檔技巧總結(jié)(包括word,excel,access,ppt)》、《php日期與時(shí)間用法總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- ajax post下載flask文件流以及中文文件名問題
- javascript寫一個(gè)ajax自動(dòng)攔截并下載數(shù)據(jù)代碼實(shí)例
- SpringMVC+Ajax實(shí)現(xiàn)文件批量上傳和下載功能實(shí)例代碼
- Ajax請(qǐng)求二進(jìn)制流進(jìn)行處理(ajax異步下載文件)的簡(jiǎn)單方法
- 利用 FormData 對(duì)象和 Spring MVC 配合實(shí)現(xiàn)Ajax文件下載功能
- 基于Blod的ajax進(jìn)度條下載實(shí)現(xiàn)示例代碼
- PHP中ajax無(wú)刷新上傳圖片與圖片下載功能
- 使用Ajax生成的Excel文件并下載的實(shí)例
- jQuery的ajax下載blob文件
- jQuery+Ajax+PHP彈出層異步登錄效果(附源碼下載)
- 前端ajax請(qǐng)求+后端java實(shí)現(xiàn)的下載zip壓縮包功能示例
相關(guān)文章
PHP如何刪除關(guān)聯(lián)數(shù)組中鍵值
在本篇文章里小編給大家整理的是一篇關(guān)于PHP刪除關(guān)聯(lián)數(shù)組中鍵值的方法,有需要的朋友們可以學(xué)習(xí)參考下。2021-08-08PHP實(shí)現(xiàn)的MD5結(jié)合RSA簽名算法實(shí)例
這篇文章主要介紹了PHP實(shí)現(xiàn)的MD5結(jié)合RSA簽名算法,結(jié)合實(shí)例形式分析了php使用md5結(jié)合RSA實(shí)現(xiàn)的簽名算法相關(guān)操作技巧,并附帶了RSA公鑰與私鑰的相關(guān)說明,需要的朋友可以參考下2017-10-10php中記錄用戶訪問過的產(chǎn)品,在cookie記錄產(chǎn)品id,id取得產(chǎn)品信息
php中記錄用戶訪問過的產(chǎn)品,在cookie記錄產(chǎn)品id,id取得產(chǎn)品信息,需要的朋友可以參考下。2011-05-05php管理nginx虛擬主機(jī)shell腳本實(shí)例
這篇文章主要介紹了php管理nginx虛擬主機(jī)shell腳本的實(shí)現(xiàn)方法,以實(shí)例形式講述了通過PHP腳本管理nginx虛擬主機(jī)的方法,具有不錯(cuò)的借鑒價(jià)值,需要的朋友可以參考下2014-11-11