欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP+Ajax實(shí)現(xiàn)的無刷新分頁功能詳解【附demo源碼下載】

 更新時(shí)間:2017年07月03日 11:38:51   作者:china_skag  
這篇文章主要介紹了PHP+Ajax實(shí)現(xiàn)的無刷新分頁功能,結(jié)合具體實(shí)例形式分析了php+ajax通過pdo操作類讀取數(shù)據(jù)庫并分頁顯示的相關(guān)實(shí)現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下

本文實(shí)例講述了PHP+Ajax實(shí)現(xiàn)的無刷新分頁功能。分享給大家供大家參考,具體如下:

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

本文講解 Ajax 實(shí)現(xiàn)無刷新分頁、實(shí)現(xiàn)原理、代碼展示、代碼下載。

這里需要說明一些知識:

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

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

3、實(shí)現(xiàn)原理:通過前端 JS 腳本程序與 Ajax 相結(jié)合取得從動態(tài)頁面返回的數(shù)據(jù),并顯示。

好了,下面進(jìn)行代碼講解:

既然,是運(yùn)行在靜態(tài)頁面上,我們首先先創(chuàng)建一個(gè)靜態(tài) 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 實(shí)現(xiàn)無刷新頁面</title>
<style type="text/css">
 body {
  font-size:12px;
 }
</style>
</head>
<body>
 <div id="fpage">數(shù)據(jù)加載中...</div>
</body>
</html>

代碼清單中,我們加載了一個(gè) Ajax 類庫,這個(gè)類庫可以在 http://www.dbjr.com.cn/article/82066.htm 文章中找到(并附有使用方法)

在這個(gè)靜態(tài)頁面中,只會顯示一個(gè)“數(shù)據(jù)加載中....”,并沒有任何數(shù)據(jù)。這時(shí),我們就需要一個(gè) JS 腳本來實(shí)現(xiàn)通過 Ajax 從數(shù)據(jù)庫中獲取數(shù)據(jù)。JS 腳本如下:

<script type="text/javascript">
 /**
 * setPage(url) 根據(jù) url 從 article.php 中獲取數(shù)據(jù)
 * @param int pageNum 頁碼
 * @return string
 */
 var cache=new Array(); // 緩存變量,當(dāng)數(shù)據(jù)被訪問過之后放置在緩存中,加快訪問速度
 function setPage(pageNum) {
  var fpage = document.getElementById('fpage'); // 獲取 fpage 對象
  // 如果緩存中存在數(shù)據(jù),那么直接從緩存中讀取;如果不存在數(shù)據(jù),那么就從數(shù)據(jù)庫中讀取,并把數(shù)據(jù)存入緩存
  if (typeof(cache[pageNum])=='undefined') {
   var ajax = Ajax();
   ajax.get('article.php?page='+pageNum, function(data){
    fpage.innerHTML = data; // fpage對象的內(nèi)容是從 article.php 中取來的
    cache[pageNum] = data;
   })
  } else {
   fpage.innerHTML = cache[pageNum];
  }
 }
 setPage(1); // 默認(rèn)執(zhí)行
</script>

仔細(xì)閱讀上面的代碼,您會發(fā)現(xiàn)下面現(xiàn)象:

1、setPage(pageNum) 是一個(gè)從數(shù)據(jù)庫中提取數(shù)據(jù)的 JS 函數(shù)接口;
2、Ajax 是通過 article.php 文件來獲取數(shù)據(jù);
3、article.php?page=xx,這里的 xx 就是所要取得的頁碼數(shù)據(jù),
setPage(1):就是取得第1頁數(shù)據(jù);
setPage(2):就是取得第2頁數(shù)據(jù);
setPage(100):就是取得第100頁數(shù)據(jù);
……
那么,如何從 article.php 文件中取得數(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為每頁顯示十條
$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ù)比較大,代碼打包下載中會附加 article.sql 文件,以便大家測試。

靜態(tài)頁面 index.html 上顯示的數(shù)據(jù)就是 article.php 文件中 echo 的代碼。

代碼文件中的 config.inc.php 文件主要就是定義一些常量,比如:數(shù)據(jù)庫用戶名、數(shù)據(jù)庫密碼、主機(jī)……,數(shù)據(jù)庫連接類庫(Db.class.php)和數(shù)據(jù)庫操作類庫(Model.class.php),請參考文章http://www.dbjr.com.cn/article/82063.htm,附有使用方法。

程序效果圖:

下圖標(biāo)注的是注意關(guān)注的地方。

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

即:

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

具體細(xì)節(jié)請大家下載代碼閱讀即可。

完整代碼點(diǎn)擊此處本站下載。

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫技巧總結(jié)》、《php+Oracle數(shù)據(jù)庫程序設(shè)計(jì)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 淺談PHP的exec()函數(shù)無返回值排查方法(必看)

    淺談PHP的exec()函數(shù)無返回值排查方法(必看)

    下面小編就為大家?guī)硪黄獪\談PHP的exec()函數(shù)無返回值排查方法(必看)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-03-03
  • Ext.data.PagingMemoryProxy分頁一次性讀取數(shù)據(jù)的實(shí)現(xiàn)代碼

    Ext.data.PagingMemoryProxy分頁一次性讀取數(shù)據(jù)的實(shí)現(xiàn)代碼

    Ext.data.PagingMemoryProxy分頁一次性讀取數(shù)據(jù)的實(shí)現(xiàn)代碼,需要的朋友可以參考下。
    2010-04-04
  • PHP云打印類完整示例

    PHP云打印類完整示例

    這篇文章主要介紹了PHP云打印類,結(jié)合完整實(shí)例形式分析了php實(shí)現(xiàn)網(wǎng)絡(luò)打印數(shù)據(jù)的搜集與隊(duì)列排序整理及數(shù)據(jù)打印等功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2016-10-10
  • 探討如何使用SimpleXML函數(shù)來加載和解析XML文檔

    探討如何使用SimpleXML函數(shù)來加載和解析XML文檔

    本篇文章是對使用SimpleXML函數(shù)來加載和解析XML文檔進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • Referer原理與圖片防盜鏈實(shí)現(xiàn)方法詳解

    Referer原理與圖片防盜鏈實(shí)現(xiàn)方法詳解

    這篇文章主要介紹了Referer原理與圖片防盜鏈實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了Referer頭信息原理與圖片防盜鏈判定、實(shí)現(xiàn)方法,并附帶一個(gè)Http請求封裝類,需要的朋友可以參考下
    2019-07-07
  • php編程每天必學(xué)之表單驗(yàn)證

    php編程每天必學(xué)之表單驗(yàn)證

    php編程每天必學(xué)之表單驗(yàn)證,針對php表單處理進(jìn)行學(xué)習(xí)研究,以一個(gè)完整例子實(shí)現(xiàn)了php表單驗(yàn)證,感興趣的小伙伴們可以參考一下
    2016-03-03
  • php用戶名的密碼加密更安全的方法

    php用戶名的密碼加密更安全的方法

    在本篇文章里小編給大家整理了關(guān)于php用戶名的密碼加密更安全的方法和相關(guān)知識點(diǎn),有興趣的朋友們參考下。
    2019-06-06
  • PHP提供下載功能實(shí)現(xiàn)案例

    PHP提供下載功能實(shí)現(xiàn)案例

    這篇文章主要為大家介紹了PHP提供下載功能實(shí)現(xiàn)案例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • PHP session反序列化漏洞超詳細(xì)講解

    PHP session反序列化漏洞超詳細(xì)講解

    這篇文章主要介紹了PHP?session反序列化漏洞,php?session反序列化漏洞存在的原因是當(dāng)序列化session和讀取反序列化字符時(shí)采用的序列化選擇器不一樣時(shí),處理的方法不一樣
    2023-02-02
  • PHP實(shí)現(xiàn)動態(tài)表單生成工具詳解

    PHP實(shí)現(xiàn)動態(tài)表單生成工具詳解

    表單包含多種input類型,包括 hiiden類型 ,text類型,radio類型等。但手寫表單累,耗時(shí)耗力,開發(fā)銷量太低且代碼量大了還容易寫出bug,所以本文將用PHP編寫動態(tài)表單生成工具,需要的可以參考一下
    2022-03-03

最新評論