2016/3/27 分页 共X条数据 本页x条 本页从x-y条 x/y页 首页 上一页 123456 下一页 末页 pagego echo $page->fpage(7,6,5,4,3,2,1,0);
显示效果:
fpage.class.php
- <?php
- /**
- file: page.class.php
- 完美分页类 Page
- */
- class Page {
- private $total; //数据表中总记录数
- private $listRows; //每页显示行数
- private $limit; //SQL语句使用limit从句,限制获取记录个数
- private $uri; //自动获取url的请求地址
- private $pageNum; //总页数
- private $page; //当前页
- private $config = array(
- 'head' => "条记录",
- 'prev' => "上一页",
- 'next' => "下一页",
- 'first'=> "首页",
- 'last' => "末页"
- );
- //在分页信息中显示内容,可以自己通过set()方法设置
- private $listNum = 10; //默认分页列表显示的个数
- /**
- 构造方法,可以设置分页类的属性
- @param int $total 计算分页的总记录数
- @param int $listRows 可选的,设置每页需要显示的记录数,默认为25条
- @param mixed $query 可选的,为向目标页面传递参数,可以是数组,也可以是查询字符串格式
- @param bool $ord 可选的,默认值为true, 页面从第一页开始显示,false则为最后一页
- */
- public function __construct($total, $listRows=25, $query="", $ord=true){
- $this->total = $total;
- $this->listRows = $listRows;
- $this->uri = $this->getUri($query);
- $this->pageNum = ceil($this->total / $this->listRows);
- /*以下判断用来设置当前面*/
- if(!empty($_GET["page"])) {
- $page = $_GET["page"];
- }else{
- if($ord)
- $page = 1;
- else
- $page = $this->pageNum;
- }
- if($total > 0) {
- if(preg_match('/\D/', $page) ){
- $this->page = 1;
- }else{
- $this->page = $page;
- }
- }else{
- $this->page = 0;
- }
- $this->limit = "LIMIT ".$this->setLimit();
- }
- /**
- 用于设置显示分页的信息,可以进行连贯操作
- @param string $param 是成员属性数组config的下标
- @param string $value 用于设置config下标对应的元素值
- @return object 返回本对象自己$this, 用于连惯操作
- */
- function set($param, $value){
- if(array_key_exists($param, $this->config)){
- $this->config[$param] = $value;
- }
- return $this;
- }
- /* 不是直接去调用,通过该方法,可以使用在对象外部直接获取私有成员属性limit和page的值 */
- function __get($args){
- if($args == "limit" || $args == "page")
- return $this->$args;
- else
- return null;
- }
- /**
- 按指定的格式输出分页
- @param int 0-7的数字分别作为参数,用于自定义输出分页结构和调整结构的顺序,默认输出全部结构
- @return string 分页信息内容
- */
- function fpage(){
- $arr = func_get_args();
- $html[0] = "<span class='p1'> 共<b> {$this->total} </b>{$this->config["head"]} </span>";
- $html[1] = " 本页 <b>".$this->disnum()."</b> 条 ";
- $html[2] = " 本页从 <b>{$this->start()}-{$this->end()}</b> 条 ";
- $html[3] = " <b>{$this->page}/{$this->pageNum}</b>页 ";
- $html[4] = $this->firstprev();
- $html[5] = $this->pageList();
- $html[6] = $this->nextlast();
- $html[7] = $this->goPage();
- $fpage = '<div style="font:12px \'\5B8B\4F53\',san-serif;">';
- if(count($arr) < 1)
- $arr = array(0,1,2,3,4,5,6,7);
- for($i = 0; $i < count($arr); $i++)
- $fpage .= $html[$arr[$i]];
- $fpage .= '</div>';
- return $fpage;
- }
- /* 在对象内部使用的私有方法,*/
- private function setLimit(){
- if($this->page > 0)
- return ($this->page-1)*$this->listRows.", {$this->listRows}";
- else
- return 0;
- }
- /* 在对象内部使用的私有方法,用于自动获取访问的当前URL */
- private function getUri($query){
- $request_uri = $_SERVER["REQUEST_URI"];
- $url = strstr($request_uri,'?') ? $request_uri : $request_uri.'?';
- if(is_array($query))
- $url .= http_build_query($query);
- else if($query != "")
- $url .= "&".trim($query, "?&");
- $arr = parse_url($url);
- if(isset($arr["query"])){
- parse_str($arr["query"], $arrs);
- unset($arrs["page"]);
- $url = $arr["path"].'?'.http_build_query($arrs);
- }
- if(strstr($url, '?')) {
- if(substr($url, -1)!='?')
- $url = $url.'&';
- }else{
- $url = $url.'?';
- }
- return $url;
- }
- /* 在对象内部使用的私有方法,用于获取当前页开始的记录数 */
- private function start(){
- if($this->total == 0)
- return 0;
- else
- return ($this->page-1) * $this->listRows+1;
- }
- /* 在对象内部使用的私有方法,用于获取当前页结束的记录数 */
- private function end(){
- return min($this->page * $this->listRows, $this->total);
- }
- /* 在对象内部使用的私有方法,用于获取上一页和首页的操作信息 */
- private function firstprev(){
- if($this->page > 1) {
- $str = " <a href='{$this->uri}page=1'>{$this->config["first"]}</a> ";
- $str .= "<a href='{$this->uri}page=".($this->page-1)."'>{$this->config["prev"]}</a> ";
- return $str;
- }
- }
- /* 在对象内部使用的私有方法,用于获取页数列表信息 */
- private function pageList(){
- $linkPage = " <b>";
- $inum = floor($this->listNum/2);
- /*当前页前面的列表 */
- for($i = $inum; $i >= 1; $i--){
- $page = $this->page-$i;
- if($page >= 1)
- $linkPage .= "<a href='{$this->uri}page={$page}'>{$page}</a> ";
- }
- /*当前页的信息 */
- if($this->pageNum > 1)
- $linkPage .= "<span style='padding:1px 2px;background:#BBB;color:white'>{$this->page}</span> ";
- /*当前页后面的列表 */
- for($i=1; $i <= $inum; $i++){
- $page = $this->page+$i;
- if($page <= $this->pageNum)
- $linkPage .= "<a href='{$this->uri}page={$page}'>{$page}</a> ";
- else
- break;
- }
- $linkPage .= '</b>';
- return $linkPage;
- }
- /* 在对象内部使用的私有方法,获取下一页和尾页的操作信息 */
- private function nextlast(){
- if($this->page != $this->pageNum) {
- $str = " <a href='{$this->uri}page=".($this->page+1)."'>{$this->config["next"]}</a> ";
- $str .= " <a href='{$this->uri}page=".($this->pageNum)."'>{$this->config["last"]}</a> ";
- return $str;
- }
- }
- /* 在对象内部使用的私有方法,用于显示和处理表单跳转页面 */
- private function goPage(){
- if($this->pageNum > 1) {
- return ' <input style="width:20px;height:17px !important;height:18px;border:1px solid #CCCCCC;" type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>'.$this->pageNum.')?'.$this->pageNum.':this.value;location=\''.$this->uri.'page=\'+page+\'\'}" value="'.$this->page.'"><input style="cursor:pointer;width:25px;height:18px;border:1px solid #CCCCCC;" type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.previousSibling.value;location=\''.$this->uri.'page=\'+page+\'\'"> ';
- }
- }
- /* 在对象内部使用的私有方法,用于获取本页显示的记录条数 */
- private function disnum(){
- if($this->total > 0){
- return $this->end()-$this->start()+1;
- }else{
- return 0;
- }
- }
- }
DBDA.php
- <?php
- class DBDA
- {
- public $host="localhost";//服务器地址
- public $uid="root";//数据库的用户名
- public $pwd="123";// 数据库的密码
- //public $dbname="test2";
- //默认要操作的数据库
- //函数 1 代表查询
- //执行sql语句,返回相应结果的函数
- //$sql是要执行的SQL语句
- //$type是SQL语句的类型,0代表增删改,1代表查询
- //$db代表要操作的数据库
- public function Query($sql,$type=1,$db="test2")
- {
- //造连接对象
- $conn=new mysqli($this->host,$this->uid,$this->pwd,$db);
- //判断连接是否成功
- !mysqli_connect_error()or die("连接失败!");
- //执行SQL语句
- $result=$conn->query($sql);
- //判断SQL语句类型
- if ($type=1)
- { //如果是查询语句返回结果集
- return $result->fetch_all();
- }
- else
- { //如果是其他语句,返回true或false
- return $result;
- }
- }
- }
- ?>
test.php
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Document</title>
- </head>
- <body>
- <table width=80% border="1" cellspacing="0" cellpadding="0">
- <tr>
- <td>地区代号</td>
- <td>地区名称</td>
- <td>地区父级代号</td>
- </tr>
- <?php
- //加载类
- include("DBDA.php");
- //造连接对象
- $db=new DBDA();
- $sqlcount="select count(*)from ChinaStates";
- $attrs=$db->query($sqlcount);
- $total=$attrs[0][0];
- //加载类
- include("fpage.class.php");
- //造分页对象
- $page=new Page($total,20,"",true);
- //set函数
- $page->set('head','条数据');
- $page->set("prev","<img src='0063.png' width='15' height='15'>");
- $page->set('first','第一页');
- //显示
- $sql="select * from ChinaStates ".$page->limit;
- $attr=$db->query($sql);
- for ($i=0; $i <count($attr) ; $i++)
- {
- echo "<tr><td>{$attr[$i][0]}</td><td>{$attr[$i][1]}</td><td>{$attr[$i][2]}</td></tr>";
- }
- echo "<tr><td>{$page->fpage()}</td></tr>";
- ?>
- </table>
- <?php
- ?>
- </body>
- </html>
显示:
2016/3/27 分页 共X条数据 本页x条 本页从x-y条 x/y页 首页 上一页 123456 下一页 末页 pagego echo $page->fpage(7,6,5,4,3,2,1,0);的更多相关文章
- 一张自增表里面总共有 7 条数据,删除了最后 2 条数据,重启 MySQL 数据库,又插入了一条数据,此时 id 是几?如何获取当前数据库版本?
一张自增表里面总共有 7 条数据,删除了最后 2 条数据,重启 MySQL 数据库,又插入了一条数据,此时 id 是几? 一般情况下,我们创建的表的类型是InnoDB,如果新增一条记录(不重启mysq ...
- 动态sql语句,非存储过程,如何判断某条数据是否存在,如果不存在就添加一条
已知一个表 table 里面有两个字段 A1 和 A2 如何用动态语句 判断 A1 = A , A2=B 的数据是否存在,如果不存在,就添加一条数据, A1 = A , A2 = B INSERT ...
- Mysql分片后分页排序拉取数据的方法
高并发大流量的互联网架构,一般通过服务层来访问数据库,随着数据量的增大,数据库需要进行水平切分,分库后将数据分布到不同的数据库实例(甚至物理机器)上,以达到降低数据量,增加实例数的扩容目的. 一旦涉及 ...
- 插入1000万条数据到mysql数据库表
转自:https://www.cnblogs.com/fanwencong/p/5765136.html 我用到的数据库为,mysql数据库5.7版本的 1.首先自己准备好数据库表 其实我在插入100 ...
- 绝对干货,教你4分钟插入1000万条数据到mysql数据库表,快快进来
我用到的数据库为,mysql数据库5.7版本的 1.首先自己准备好数据库表 其实我在插入1000万条数据的时候遇到了一些问题,现在先来解决他们,一开始我插入100万条数据时候报错,控制台的信息如下: ...
- sql 更新列表中最老的一条数据
今天组长给个任务说要给摄像头触发一个列表.让缓存5条数据,每次摄像头触发更新一条,丢掉最老的一条数据.原来的update是直接更新掉一条,没带缓存的.然后搞了个sql语句,是这样的: UPDATE C ...
- 实现java 中 list集合中有几十万条数据,每100条为一组取出
解决"java 中 list集合中有几十万条数据,每100条为一组取出来如何实现,求代码!!!"的问题. 具体解决方案如下: /** * 实现java 中 list集合中有几十万条 ...
- 【sql进阶】查询每天、每个设备的第一条数据
需求如下 每个设备(不同DeviceID).每天会向数据库插入多条数据,求每天.每个设备插入的第一条数据. 下面SQL中的 ShareRecommendID 类比不同设备的DeviceID. ROW_ ...
- mysql中删除重复记录,并保留重复数据中的一条数据的SQL语句
正好想写一条删除重复语句并保留一条数据的SQL,网上查了一部分资料写的很详细,但还是在这里写下自己的理解,以遍后续学习 .如下: 表字段和数据: SQL语句: [sql] view plain cop ...
随机推荐
- vue 框架原理
参考:https://segmentfault.com/a/1190000006599500#articleHeader4 记录自己的理解: 核心的响应原理通过Object.definePropert ...
- react深入 - 手写实现react-redux api
简介:简单实现react-redux基础api react-redux api回顾 <Provider store>把store放在context里,所有子组件可以直接拿到store数据 ...
- LoadRunner中的参数与变量-产生20位的随机数
LoadRunner中的参数与变量-产生20位的随机数 在LoadRunner脚本开发中,经常会遇到参数与变量相互转换的情况,本文对常见的转换情形进行了方法总结. 1.变量的赋值 //将字符串赋值给变 ...
- left join 与left outer join的区别
joinn 语句有三种:inner join, left outer join 和 right outer join都可以简写,分别为join,left join,right join.
- [luoguP1027] Car的旅行路线(Floyd)
传送门 建图麻烦,建完图搞一遍Floyd就好了. ——代码 #include <iostream> #include <cstdio> #include <cmath&g ...
- 修改textfield的占位符颜色
[self.titleField setValue:UIColorFromHEXWithAlpha(0x999999, 1) forKeyPath:@"_placeholderLabel.t ...
- oc温习五:字符串
/** substringFromIndex: --从第from位数 开始截取字符串 */ NSString *str = @"asdfghjkzxcbnm"; NSString ...
- POJ 1661 Help Jimmy【DP】
基础DP,过程想明白了其实也不复杂,从上面的推下面的比倒着推要简单很多.调试了半个多小时..简单dp依然不能快速AC..SAD.. 题目链接: http://poj.org/problem?id=16 ...
- POJ 2965 The Pilots Brothers' refrigerator【BFS+状压 Or 脑洞】
题目链接: http://poj.org/problem?id=1753 题意: 给定冰箱门的开关情况,改变一个门则其所在行列的门都会发生改变,求出改变门的最少操作使得最终所有门都是打开状态. 代码: ...
- T1503 愚蠢的宠物 codevs
http://codevs.cn/problem/1503/ 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 大家都知道,sh ...