上一次说了PHP+MYSQL实现内容分页的代码,但是项目的需求有时候需要用户进行搜索,然后展示相应的内容,如果内容太多,也要进行分页。
最后做完的结果如下:
![](https://box.kancloud.cn/86a780c6020afd88d8bee97a9277a9ca_321x173.jpg)
测试代码如下,总共分为2个PHP文件。
第一个:searchPage.php
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title></title>
<meta name="keywords" content="" />
<mtea name="description" content="" />
<style type="text/css">
table{margin:10px 0px 0px 0px;}
td{border:1px solid #ccc;padding:0px 10px;}
</style>
</head>
<body>
<div class="search">
<form method="get" action="">
<input type="text" name="teacherMessage" id="searchTxt" placeholder="老师年龄(20-60)" />
<input type="submit" name="sub" id="searchBtn" value="搜索" />
</form>
</div>
<table cellpadding="0" cellspacing="0">
<thead>
<tr>
<td>ID</td>
<td>名字</td>
<td>年龄</td>
<td>性别</td>
</tr>
</thead>
<tbody>
<?php
include 'page.php';
header('content-type:text/html;charset="utf-8"');
function show($teacherMessage){
global $teacher;
$teacher = new Teacher($teacherMessage);
$card = $teacher->getContent();
$len = count($card);
if($len==0){
echo '<script type="text/javascript">alert("没有找到您想要的信息")</script>';
}else{
foreach($card as $v){
echo '<tr><td>'.$v['id'].'</td><td>'.$v['tname'].'</td><td>'.$v['tage'].'</td><td>'.$v['tsex'].'</td></tr>';
}
}
}
if($_GET['sub']=='搜索'){
$teacherMessage = $_GET['teacherMessage'];
if(!empty($teacherMessage)){
show($teacherMessage);
}else{
echo '<script type="text/javascript">alert("内容为空");</script>';
}
}else{
show('23');
}
?>
</tbody>
</table>
<div class="pageList">
<?php
if($teacher){
echo $teacher->pageStyle();
unset($teacher);
}
?>
</div>
</body>
</html>
<script type="text/javascript">
var oSearchTxt = document.getElementById('searchTxt');
oSearchTxt.onblur = blurValidate;
//鼠标移出输入框,判断输入内容是否为空
function blurValidate(){
if(!this.value){
alert('内容不能为空');
return;
}
}
</script>
第二个:page.php
<?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;//数据库信息
private $teacherMessage;//用户输入的搜索信息
public function __construct($teacherMessage){
$this->teacherMessage = $teacherMessage;
$this->pdo = $this->getDb();
$query = 'select id,tname,tage,tsex from teacher where tage like "%'.$this->teacherMessage.'%"';
$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;
$a = 'zhangsan';
$query = 'select id,tname,tage,tsex from teacher where tage like "%'.$this->teacherMessage.'%" order by id desc 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();
}
}
?>
数据内容如下,可以自己去配置一个作为测试:
![](https://box.kancloud.cn/92c017bfa27335168a6c2f8c1f173a39_374x282.jpg =500x500)
- 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技术结合使用解析