首頁 >後端開發 >php教程 >PHP+Ajax實作無刷新分頁的方法及實例詳解

PHP+Ajax實作無刷新分頁的方法及實例詳解

墨辰丷
墨辰丷原創
2018-06-04 10:00:442191瀏覽

這篇文章主要介紹了PHP Ajax實現無刷新分頁的方法,以完整實例形式詳細分析了PHP結合ajax實現無刷新分頁的具體步驟與相關技巧,並附帶demo源碼供讀者下載參考,需要的朋友可以參考下

:這裡使用到的一些類別庫在前面文章都能找到原始程式碼,因此為了縮短文章篇幅,都指明連結所在。

本文解說內容為: Ajax 實作無刷新分頁、實作原理、程式碼展示、程式碼下載。

這裡需要說明一些知識:

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

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

3、實作原理:透過前端 JS 腳本程式與 Ajax 結合取得從動態頁面傳回的數據,並顯示。

好了,下面進行程式碼講解:

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

index.html

<!DOCTYPE html>
<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>
  <p id="fpage">数据加载中...</p>
</body>
</html>

#程式碼清單中,我們載入了一個Ajax 類別庫,這個類別庫可以在前面一篇《一個簡單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(&#39;fpage&#39;); // 获取 fpage 对象
    // 如果缓存中存在数据,那么直接从缓存中读取;如果不存在数据,那么就从数据库中读取,并把数据存入缓存
    if (typeof(cache[pageNum])==&#39;undefined&#39;) {
      var ajax = Ajax();
      ajax.get(&#39;article.php?page=&#39;+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 &#39;./config.inc.php&#39;;
$m = new Model();
$page = new ajaxPage($m->total(&#39;article&#39;),20); // $m->total(&#39;article&#39;) 获取 article 表的记录数;10为每页显示十条
$result = $m->fetchAll(&#39;article&#39;, &#39;*&#39;, &#39;&#39;, &#39;&#39;, $page->limit); // 取出数据,^_^,很方便吧
echo &#39;<table align="center" border="1" width="1100" style="border-collapse:collapse;font-size:14px;" bordercolor="#666">&#39;;
echo &#39;<caption><h1>华强电子网资讯</h1></caption>&#39;;
echo &#39;<tr height="25"><th>ID</th><th>Title</th><th>Author</th><th>Source</th><th>Date</th></tr>&#39;;
foreach ($result as $v) {
  echo "<tr height=&#39;21&#39;><td align=&#39;center&#39;>{$v[&#39;id&#39;]}</td><td>{$v[&#39;title&#39;]}</td><td align=&#39;center&#39;>{$v[&#39;author&#39;]}</td><td align=&#39;center&#39;>{$v[&#39;source&#39;]}</td><td align=&#39;center&#39;>{$v[&#39;date&#39;]}</td></tr>";
}
echo &#39;<tr><td align="right" colspan="5">&#39;.$page->fpage().&#39;</td></tr>&#39;;
echo &#39;</table>&#39;;
?>

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實作登入驗證碼功能及呼叫方法

php中檔案上傳後端處理的技巧

PHP取得網站中文章的第一張圖片作為縮圖的方法

以上是PHP+Ajax實作無刷新分頁的方法及實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn