- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章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
|
<!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 脚本如下:
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),请参考文章http://www.zzvips.com/article/130241.html,附有使用方法.
程序效果图:
下图标注的是注意关注的地方.
这样,Ajax 无刷新分页就完成了。程序中还有一个 ajaxPage.class.php 没有说明,其实,这个 ajaxPage 类库的使用方法和一般的分页类库是一样的.
即:
1
|
$page
=
new
ajaxPage(记录总数, 每页显示数);
|
具体细节请大家下载代码阅读即可.
完整代码点击此处本站下载.
希望本文所述对大家PHP程序设计有所帮助.
最后此篇关于PHP+Ajax实现的无刷新分页功能详解【附demo源码下载】的文章就讲到这里了,如果你想了解更多关于PHP+Ajax实现的无刷新分页功能详解【附demo源码下载】的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我在 JavaScript 文件中运行 PHP,例如...... var = '';). 我需要使用 JavaScript 来扫描字符串中的 PHP 定界符(打开和关闭 PHP 的 )。 我已经知道使
我希望能够做这样的事情: php --determine-oldest-supported-php-version test.php 并得到这个输出: 7.2 也就是说,php 二进制检查 test.
我正在开发一个目前不使用任何框架的大型 php 站点。我的大问题是,随着时间的推移慢慢尝试将框架融入应用程序是否可取,例如在创建的新部件和更新的旧部件中? 比如所有的页面都是直接通过url服务的,有几
下面是我的源代码,我想在同一页面顶部的另一个 php 脚本中使用位于底部 php 脚本的变量 $r1。我需要一个简单的解决方案来解决这个问题。我想在代码中存在的更新查询中使用该变量。 $name)
我正在制作一个网站,根据不同的情况进行大量 PHP 重定向。就像这样...... header("Location: somesite.com/redirectedpage.php"); 为了安全起见
我有一个旧网站,我的 php 标签从 因为短标签已经显示出安全问题,并且在未来的版本中将不被支持。 关于php - 如何避免在 php 文件中写入
我有一个用 PHP 编写的配置文件,如下所示, 所以我想用PHP开发一个接口(interface),它可以编辑文件值,如$WEBPATH , $ACCOUNTPATH和 const值(value)观
我试图制作一个登录页面来学习基本的PHP,首先我希望我的独立PHP文件存储HTML文件的输入(带有表单),但是当我按下按钮时(触发POST到PHP脚本) )我一直收到令人不愉快的错误。 我已经搜索了S
我正在寻找一种让 PHP 以一种形式打印任意数组的方法,我可以将该数组作为赋值包含在我的(测试)代码中。 print_r 产生例如: Array ( [0] => qsr-part:1285 [1]
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: What is the max key size for an array in PHP? 正如标题所说,我想知道
我正在寻找一种让 PHP 以一种形式打印任意数组的方法,我可以将该数组作为赋值包含在我的(测试)代码中。 print_r 产生例如: Array ( [0] => qsr-part:1285 [1]
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我在 MySQL 数据库中有一个表,其中存储餐厅在每个工作日和时段提供的菜单。 表结构如下: i_type i_name i_cost i_day i_start i_
我有两页。 test1.php 和 test2.php。 我想做的就是在 test1.php 上点击提交,并将 test2.php 显示在 div 中。这实际上工作正常,但我需要向 test2.php
我得到了这个代码。我想通过textarea更新mysql。我在textarea中回显我的MySQL,但我不知道如何更新它,我应该把所有东西都放进去吗,因为_GET模式没有给我任何东西,我也尝试_GET
首先,我是 php 的新手,所以我仍在努力学习。我在 Wordpress 上创建了一个表单,我想将值插入一个表(data_test 表,我已经管理了),然后从 data_test 表中获取所有列(id
我有以下函数可以清理用户或网址的输入: function SanitizeString($var) { $var=stripslashes($var); $va
我有一个 html 页面,它使用 php 文件查询数据库,然后让用户登录,否则拒绝访问。我遇到的问题是它只是重定向到 php 文件的 url,并且从不对发生的事情提供反馈。这是我第一次使用 html、
我有一个页面充满了指向 pdf 的链接,我想跟踪哪些链接被单击。我以为我可以做如下的事情,但遇到了问题: query($sql); if($result){
我正在使用 从外部文本文件加载 HTML/PHP 代码 $f = fopen($filename, "r"); while ($line = fgets($f, 4096)) { print $l
我是一名优秀的程序员,十分优秀!