溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在PHP中利用Ajax實(shí)現(xiàn)一個(gè)無(wú)刷新分頁(yè)功能

發(fā)布時(shí)間:2021-02-07 20:50:02 來(lái)源:億速云 閱讀:183 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)如何在PHP中利用Ajax實(shí)現(xiàn)一個(gè)無(wú)刷新分頁(yè)功能,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

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>

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ù)被訪問(wèn)過(guò)之后放置在緩存中,加快訪問(wèn)速度
  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 中取來(lái)的
        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 是通過(guò) article.php 文件來(lái)獲取數(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

<?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"  bordercolor="#666">';
echo '<caption><h2>華強(qiáng)電子網(wǎng)資訊</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 中連接的數(shù)據(jù)是前面文章從華強(qiáng)電子網(wǎng)抓來(lái)的資訊數(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)注的地方

如何在PHP中利用Ajax實(shí)現(xiàn)一個(gè)無(wú)刷新分頁(yè)功能

這樣,Ajax 無(wú)刷新分頁(yè)就完成了。程序中還有一個(gè) ajaxPage.class.php 沒(méi)有說(shuō)明,其實(shí),這個(gè) ajaxPage 類庫(kù)的使用方法和一般的分頁(yè)類庫(kù)是一樣的。

即:$page = new ajaxPage(記錄總數(shù), 每頁(yè)顯示數(shù));

關(guān)于如何在PHP中利用Ajax實(shí)現(xiàn)一個(gè)無(wú)刷新分頁(yè)功能就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI