Ajax實現無重新整理分頁

來源:互聯網
上載者:User

標籤:php   通過   取出   答案   www   oct   str   apt   實現原理   

註:本文中使用到的一些類庫在前面文章都能找到原始碼,我會在文中指明連結所在,為了縮短文章篇幅,由此帶來的閱讀不便,敬請諒解。

本文講解 Ajax 實現無重新整理分頁、實現原理、代碼展示、代碼下載。

這裡需要說明一些知識:

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

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

3、實現原理:通過前端 JS 指令碼程式與 Ajax 相結合取得從動態網頁面返回的資料,並顯示。

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

既然,是運行在靜態頁面上,我們首先先建立一個靜態 HTML 頁面,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 類庫 -->  <title>Ajax 實現無重新整理頁面</title>  <style type="text/css">      body {          font-size:12px;       }  </style>  </head>  <body>      <div id="fpage">資料載入中...</div>  </body>  </html>  

代碼清單中,我們載入了一個 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(‘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

<?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),請參考文章 http://blog.csdn.net/liruxing1715/article/details/7176671,附有使用方法。

程式:

標註的是注意關注的地方。

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

即:$page = new ajaxPage(記錄總數, 每頁顯示數); 源碼地址:http://pan.baidu.com/share/init?shareid=1456793845&uk=1997289381;

密碼:【3gqk】

Ajax實現無重新整理分頁

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.