如果某个类目下有很多条记录,我们不可能一下子全部展现给用户,第一:用户看不完,第二:一次性全部加载性能太差。所以就需要用到翻页技术,用户看哪儿加载哪儿,这个和javascrip结合ajaxt实现瀑布流懒加载有点类似。
下面是我自己写的php分页代码,php代码和html代码放在了一个页面,仅供测试使用,如果你想用在项目里边,可以把对应的类单独放在某个php文件中,然后前端页面include引用即可。
最后做完的截图如下:
![](https://box.kancloud.cn/28a1540db9954e7a1da7ef5fa5b0dacd_363x204.jpg =500x400)
代码如下:
<?php
header('content-type:text/html;charset="utf-8"');
class Teacher{
private $current;//当前页
private $totalRecord;//总共查询到的记录数
private $pageLen = 3;//每页显示的记录数
private $totalPage;//总页数
private $url;//网址
private $startRecord;//从第几条记录开始查询
private $pdo;//数据库信息
public function __construct(){
$this->pdo = $this->getDb();
$query = 'select * from teacher';
$result = $this->pdo->query($query);
$res = $result->fetchAll(PDO::FETCH_ASSOC);
$this->current = $_GET['page'] ? $_GET['page'] : 1;
$this->url = $this->getUrl();
$this->totalRecord = count($res);
$this->totalPage = ceil($this->totalRecord/$this->pageLen);
}
//连接数据库
private function getDb(){
$pdo = new PDO('mysql:host=localhost;dbname=edu','edu','edu');
return $pdo;
}
//提取保留url地址中除page之外的其他参数
private function getUrl(){
$url = parse_url($_SERVER['REQUEST_URI']);
$query = $url['query'];
parse_str($query,$arry);
unset($arry['page']);
$newQuery = http_build_query($arry);
return $url['path'].'?'.$newQuery.'&page=';
}
//首页
private function first(){
if($this->current>1){
return '<a href="'.$this->url.'1'.'">首页</a>';
}
}
//上一页
private function pre(){
if($this->current<=$this->totalPage){
return '<a href="'.$this->url.($this->current-1).'">上一页</a>';
}
}
//下一页
private function next(){
if($this->current<$this->totalPage){
return '<a href="'.$this->url.($this->current+1).'">下一页</a>';
}
}
//末页
private function end(){
if($this->current<$this->totalPage){
return '<a href="'.$this->url.($this->totalPage).'">末页</a>';
}
}
//获取表格内容
public function getContent(){
$this->startRecord = 2*$this->current-2;
$query = 'select * from teacher where id limit '.$this->startRecord.','.$this->pageLen;
$pageResult = $this->pdo->query($query);
$pageRes = $pageResult->fetchAll(PDO::FETCH_ASSOC);
unset($this->pdo);
return $pageRes;
}
//分页样式
public function pageStyle(){
return '共有'.$this->totalPage.'页 '.$this->first().$this->pre().$this->next().$this->end();
}
}
$teacher = new Teacher();
$card = $teacher->getContent();
?>
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title></title>
<meta name="keywords" content="" />
<meta name="description" content="" />
<style type="text/css">
*{margin:0px;padding:0px;}
body{font-size:12px;}
.teacherInfo{margin:100px auto 100px 100px;}
.teacherInfo .pageList{margin-top:10px;}
a{text-decoration:none;margin-right:10px;}
a:hover{color:#f00;}
td{padding:0px 10px;height:30px;line-height:30px;border:1px solid #ccc;}
</style>
</head>
<body>
<div class="teacherInfo">
<table cellpadding="0" cellspacing="0">
<thead>
<tr>
<td>ID</td>
<td>姓名</td>
<td>年龄</td>
<td>性别</td>
</tr>
</thead>
<tbody>
<?php
$len = count($card);
for($i=0;$i<$len;$i++){
echo '<tr><td>'.$card[$i]["id"].'</td><td>'.$card[$i]["tname"].'</td><td>'.$card[$i]["tage"].'</td><td>'.$card[$i]["tsex"].'</td></tr>';
}
?>
</tbody>
</table>
<div class="pageList">
<?php
echo $teacher->pageStyle();
?>
</div>
</div>
</body>
</html>
数据库中的记录截图如下:
![](https://box.kancloud.cn/92c017bfa27335168a6c2f8c1f173a39_374x282.jpg =500x600)
- 0、php安装
- 1、选择PHP作为首选后端语言的原因
- 2、PHP基本语法
- 3、PHP中变量和常量的区别
- 4、PHP中单引号和双引号的区别
- 5、PHP检测数据类型的几种方式
- 6、PHP数据类型转换
- 7、return、break、continue的区别
- 8、PHP代码重用
- 9、字符串移除或添加函数
- 10、PHP中字符串大小写切换以及翻转和加密
- 11、PHP字符串截取和截取函数
- 12、PHP字符串替换和比较函数
- 13、PHP字符串url解析和实体转换
- 14、addslashes在预定义字符串前添加反斜杠
- 15、PHP中的数组基本概念
- 16、数组函数implode、explode、in_array、each、list
- 17、PHP数组函数(count、reset、end、next、current、key)
- 18、ZendStudio软件破解安装包免费下载
- 19、【图文】ZendStudio汉化方法
- 20、数组函数in_array、array_search、array_change_key_case、array_chu
- 21、关闭PHP提示的方法(运行出现Notice : Use of undefined constant 的完美解决方案
- 22、PHP数组函数(array_diff_ukey、array_diff_uassoc、array_intersect
- 23、PHP数组函数(array_fill、array_filter、array_flip、array_key_exis
- 24、PHP数组去重及向前向后删除元素的函数
- 25、PHP数组函数(array_map、array_walk、array_walk_recursive)
- 26、PHP数组函数(compact、extract)
- 27、PHP数组函数(array_merge、array_merge_recursive)
- 28、PHP数组函数(range、array_count_values、array_product)
- 29、PHP数组函数(array_reduce、array_slice、array_splice、array_sum)
- 30、PHP数组排序函数总结
- 31、PHP中面向对象的基本概念及定义对象的方法
- 32、PHP创建对象与构造函数
- 33、PHP对象的释放
- 34、PHP面向对象的特性(抽象、封装、继承、多态)
- 35、PHP面向对象的public、private、protected之间的区别
- 36、PHP面向对象中的final和const的用法
- 37、PHP面向对象的static关键字
- 38、PHP中的单例模式
- 39、$this、self、parent详解
- 40、PHP中面向对象的抽象类和抽象方法
- 41、PHP面向对象中的接口interface
- 42、PHP面向对象中的魔术方法
- 43、面向对象方法get_object_vars、is_subclass_of、interface_exists
- 44、PHP中的数学函数方法总结
- 45、PHP文件处理disk_total_space、disk_free_space、dirname、file_exis
- 46、PHP目录操作rename和scandir
- 47、PHP操作目录opendir、readdir、glob
- 48、PHP打开fopen、读取fread、写入文件fwrite
- 49、PHP文件处理file_get_contents、file_put_contents、fgetc、fgets、fg
- 50、PHP截取字符串出现乱码的解决方法(UTF8和GBK)
- 51、PHP文件内容分页操作,避免乱码
- 52、PHP文件操作函数file、set_include_path、copy
- 53、PHP文件操作函数filemtime、filectime、fileatime、touch
- 54、PHP文件操作指针函数feof、ftell、fseek、rewind、fpassthru
- 55、PHP文件操作pathinfo、realpath、flock、tempnam、tmpfile
- 56、设置php.ini配置实现表单文件上传流程
- 57、PHP将上传到临时文件夹的文件移动到服务器指定文件夹内
- 58、PHP+input表单实现多文件上传
- 59、PHP通过超链接实现文件下载
- 60、发送header文件头信息实现文件下载
- 61、PHP中的日期时间_时区时间戳函数使用
- 62、PHP操作COOKIE缓冲区影响COOKIE传递方式
- 63、PHP中SESSION定义、建立、删除方式
- 64、PHP.INI配置文件中关于session的设置
- 65、HP中Session缓存的概念与用法
- 66、PHP自定义Session处理机制
- 67、通过MYSQL数据库操作Session会话完整源码类
- 68、PHP连接数据库实现分页代码
- 69、HTTP缓存实现原理详解
- 70、PHP连接数据库实现搜索+分页功能
- 71、PHP图像处理之建立画布填充颜色、打开不同图像类型处理
- 72、PHP颜色或图像填充及不同填充方式
- 73、PHP图像处理之画线&定义线样式&宽度&风格&笔刷
- 74、PHP图像处理:绘制色素及矩形图
- 75、PHP图像处理之画圆、弧线、网站饼状统计图绘制
- 76、PHP图像处理之绘制多边行及文字绘制
- 77、PHP 图像处理之获得文字宽高属性&图片水印函数功能
- 78、PHP生成图片验证码demo【OOP面向对象版本】
- 79、PHP图像处理 图像处理之处理文字及获得文字尺寸属性,imagecopymerge imagecop
- 80、替换用户输入的QQ表情
- 81、PHP封装MYSQL数据库操作类源码
- 82、PHP与XML技术结合使用解析