一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - PHP+Ajax實現無刷新分頁實例詳解(附demo源碼下載)

PHP+Ajax實現無刷新分頁實例詳解(附demo源碼下載)

2021-01-08 15:24ruxingli PHP教程

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

本文實例講述了PHP+Ajax實現無刷新分頁的方法。分享給大家供大家參考,具體如下:

:這里使用到的一些類庫在前面文章都能找到源代碼,因此為了縮短文章篇幅,都指明鏈接所在。

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

這里需要說明一些知識:

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

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

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

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

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

index.html

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<!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 類庫,這個類庫可以在 前面一篇《一個簡單Ajax類庫及使用方法實例分析》中找到

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?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),請參考文章 《PHP的PDO常用類庫實例分析》,附有使用方法。

程序效果圖:

下圖標注的是注意關注的地方

PHP+Ajax實現無刷新分頁實例詳解(附demo源碼下載)

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

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

具體細節請大家下載代碼閱讀即可。

完整實例代碼點擊此處本站下載

希望本文所述對大家PHP程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩制服丝袜在线观看 | 日本护士xxxx视频 | 邪恶肉肉全彩色无遮琉璃神社 | 九草在线视频 | 古装一级无遮挡毛片免费观看 | 草草在线视频 | 免费永久视频 | 日本老师xxxxx18 | 亚洲精品有码在线观看 | 好湿好紧太硬了我太爽了h 好湿好滑好硬好爽好深视频 | 幻女free性俄罗斯第一次摘花 | 国产小嫩模好紧 | 娇妻中日久久持久久 | 夫妻性生活一级黄色片 | porono日本人xxx | 国产精品久久久久久福利 | 国产人妖ts在线视频网 | 奇米影视奇米色777欧美 | 女海盗斯蒂内塔的复仇2免费观看 | 国产欧美日韩免费一区二区 | 青草福利视频 | 午夜看片a福利在线观看 | 国产91精选学生在线观看 | 黑人巨摘花第一次出血 | 国产3p在线 | 午夜亚洲WWW湿好爽 午夜想想爱午夜剧场 | 四虎在线永久免费视频网站 | 久久无码人妻AV精品一区 | 精品精品精品 | 国产精品一级香蕉一区 | 无人知晓小说姜璟免费阅读 | 国产精品午夜剧场 | 操姓| 日韩去日本高清在线 | 摸逼网 | 国产精品免费视频一区一 | 亚洲天堂成人在线观看 | 免费看男人使劲躁女人小说 | 青青草国产一区二区三区 | 久久91精品国产91久久户 | 四虎影视4hu最新地址在线884 |