<?php

 /**
* 页面名称:cls_page.php
*/
class Page {
private $each_disNums; //每页显示的条目数
private $nums; //总条目数
private $current_page; //当前被选中的页
private $sub_pages; //每次显示的页数
private $pageNums; //总页数
private $page_array = array (); //用来构造分页的数组
private $subPage_link; //每个分页的链接 /**
*
* __construct是SubPages的构造函数,用来在创建类的时候自动运行.
* @$each_disNums 每页显示的条目数
* @nums 总条目数
* @current_num 当前被选中的页
* @sub_pages 每次显示的页数
* @subPage_link 每个分页的链接
* @subPage_type 显示分页的类型
*
* 当@subPage_type=1的时候为普通分页模式
* example: 共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [下页] [尾页]
* 当@subPage_type=2的时候为经典分页样式
* example: 当前第1/453页 [首页] [上页] 1 2 3 4 5 6 7 8 9 10 [下页] [尾页]
*/
function __construct($each_disNums, $nums, $current_page, $sub_pages, $subPage_link) {
$this->each_disNums = intval($each_disNums);
$this->nums = intval($nums);
if (!$current_page) {
$this->current_page = 1;
} else {
$this->current_page = intval($current_page);
}
$this->sub_pages = intval($sub_pages);
$this->pageNums = ceil($nums / $each_disNums);
$this->subPage_link = $subPage_link;
}
/**
* 照顾低版本
*/
/*
function __construct($each_disNums, $nums, $current_page, $sub_pages, $subPage_linke) {
$this->Page($each_disNums, $nums, $current_page, $sub_pages, $subPage_link); }
*/ /*
__destruct析构函数,当类不在使用的时候调用,该函数用来释放资源。
*/
function __destruct() {
unset ($each_disNums);
unset ($nums);
unset ($current_page);
unset ($sub_pages);
unset ($pageNums);
unset ($page_array);
unset ($subPage_link);
} /*
用来给建立分页的数组初始化的函数。
*/
function initArray() {
for ($i = 0; $i < $this->sub_pages; $i++) {
$this->page_array[$i] = $i;
}
return $this->page_array;
} /*
construct_num_Page该函数使用来构造显示的条目
即使:[1][2][3][4][5][6][7][8][9][10]
*/
function construct_num_Page() {
if ($this->pageNums < $this->sub_pages) {
$current_array = array ();
for ($i = 0; $i < $this->pageNums; $i++) {
$current_array[$i] = $i +1;
}
} else {
$current_array = $this->initArray();
if ($this->current_page <= 3) {
for ($i = 0; $i < count($current_array); $i++) {
$current_array[$i] = $i +1;
}
}
elseif ($this->current_page <= $this->pageNums && $this->current_page > $this->pageNums - $this->sub_pages + 1) {
for ($i = 0; $i < count($current_array); $i++) {
$current_array[$i] = ($this->pageNums) - ($this->sub_pages) + 1 + $i;
}
} else {
for ($i = 0; $i < count($current_array); $i++) {
$current_array[$i] = $this->current_page - 2 + $i;
}
}
} return $current_array;
} /*
构造普通模式的分页
共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [下页] [尾页]
*/
function subPageCss1() {
$subPageCss1Str = "";
$subPageCss1Str .= "共" . $this->nums . "条记录,";
$subPageCss1Str .= "每页显示" . $this->each_disNums . "条,";
$subPageCss1Str .= "当前第" . $this->current_page . "/" . $this->pageNums . "页 ";
if ($this->current_page > 1) {
$firstPageUrl = $this->subPage_link . "1";
$prewPageUrl = $this->subPage_link . ($this->current_page - 1);
$subPageCss1Str .= "[<a href='$firstPageUrl'>首页</a>] ";
$subPageCss1Str .= "[<a href='$prewPageUrl'>上一页</a>] ";
} else {
$subPageCss1Str .= "[首页] ";
$subPageCss1Str .= "[上一页] ";
} if ($this->current_page < $this->pageNums) {
$lastPageUrl = $this->subPage_link . $this->pageNums;
$nextPageUrl = $this->subPage_link . ($this->current_page + 1);
$subPageCss1Str .= " [<a href='$nextPageUrl'>下一页</a>] ";
$subPageCss1Str .= "[<a href='$lastPageUrl'>尾页</a>] ";
} else {
$subPageCss1Str .= "[下一页] ";
$subPageCss1Str .= "[尾页] ";
} return $subPageCss1Str; } /*
构造经典模式的分页
当前第1/453页 [首页] [上页] 1 2 3 4 5 6 7 8 9 10 [下页] [尾页]
*/
function subPageCss2() {
$subPageCss2Str = "";
$subPageCss2Str .= "当前第" . $this->current_page . "/" . $this->pageNums . "页 "; if ($this->current_page > 1) {
$firstPageUrl = $this->subPage_link . "1";
$prewPageUrl = $this->subPage_link . ($this->current_page - 1);
$subPageCss2Str .= "[<a href='$firstPageUrl'>首页</a>] ";
$subPageCss2Str .= "[<a href='$prewPageUrl'>上一页</a>] ";
} else {
$subPageCss2Str .= "[首页] ";
$subPageCss2Str .= "[上一页] ";
} $a = $this->construct_num_Page();
for ($i = 0; $i < count($a); $i++) {
$s = $a[$i];
if ($s == $this->current_page) {
$subPageCss2Str .= "[<span style='color:red;font-weight:bold;'>" . $s . "</span>]";
} else {
$url = $this->subPage_link . $s;
$subPageCss2Str .= "[<a href='$url'>" . $s . "</a>]";
}
} if ($this->current_page < $this->pageNums) {
$lastPageUrl = $this->subPage_link . $this->pageNums;
$nextPageUrl = $this->subPage_link . ($this->current_page + 1);
$subPageCss2Str .= " [<a href='$nextPageUrl'>下一页</a>] ";
$subPageCss2Str .= "[<a href='$lastPageUrl'>尾页</a>] ";
} else {
$subPageCss2Str .= "[下一页] ";
$subPageCss2Str .= "[尾页] ";
}
return $subPageCss2Str;
}
} ?> <?
class sqldao{
//连接数据库
function conn(){
$dbh=mysql_connect('localhost','username','pass')or die("对不起,数据库连接错误!请稍候再来,或与管理员联系");
mysql_query("set names 'utf8'", $dbh);
mysql_select_db('tableName');
return $dbh;
}
}
?> <?
//以下为测试代码
$sqldao=new sqldao();
$dbh=$sqldao->conn(); $start=($_GET['p']-1)*10;
$que="select utname from renyuan";
$rs=mysql_query($que,$dbh);
$num_all=mysql_num_rows($rs); $rs=mysql_query($que." limit ".$start.",10",$dbh);
$num=mysql_num_rows($rs);
for($i=0;$i<$num;$i++){
$row=mysql_fetch_array($rs);
echo $row['utname']."<br>";
} echo "<hr>";
//测试一下,看看两种不同效果
//$t = new Page(显示条数, 数据总数, 页数, 页数链接个数, '页面链接');
$t = new Page(10, $num_all, $_GET['p'], 10, 'cls_page.php?p=');
echo $t->subPageCss2();
echo "<p>";
echo $t->subPageCss1(); ?>

php动态分页类的更多相关文章

  1. DedeCMS织梦动态分页类,datalist标签使用实例

    <?php require_once(dirname(__FILE__)."/include/common.inc.php");//载入基础文件 require_once(D ...

  2. Java 动态分页类

     动态分页类: Cls_page.java package pagination; public class Cls_page { private int nums;// 总条目数 private i ...

  3. PHP+jQuery 长文章分页类 ( 支持 url / ajax 分页方式 )

    /* ******* 环境:Apache2.2.8 ( 2.2.17 ) + PHP5.2.6 ( 5.3.3 ) + MySQL5.0.51b ( 5.5.8 ) + jQuery-1.8 **** ...

  4. LayUI分页,LayUI动态分页,LayUI laypage分页,LayUI laypage刷新当前页

    LayUI分页,LayUI动态分页,LayUI laypage分页,LayUI laypage刷新当前页 >>>>>>>>>>>> ...

  5. Tornado-基于正则的路由和动态分页

    概览 这一小节涉及了三部分内容: 1.动态分页设计 2.基本的路由系统以及基于正则的路由 3.模块引擎的继承和导入 4.web项目文件夹和ReuquestHandler的分类 5.跨站脚本攻击 文件结 ...

  6. Java动态生成类以及动态添加属性

    有个技术实现需求:动态生成类,其中类中的属性来自参数对象中的全部属性以及来自参数对象properties文件. 那么技术实现支持:使用CGLib代理. 具体的实现步骤: 1.配置Maven文件: &l ...

  7. customPage.class.php可添加js事件的分页类

    用于ajax动态加载数据的分页类,分页事件可以动态添加,去除了a链接中的href地址. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 ...

  8. jquery动态分页

    最近一直研究jquery的分页效果,刚刚弄好了一个,拿出来与大家分享.分页效果与时光网的差不多. 网址:http://www.mtime.com/movie/news/all/ 先在aspx页面放置一 ...

  9. php实现的分页类

    php分页类文件: <?php /** file: page.class.php 完美分页类 Page */ class Page { private $total; //数据表中总记录数 pr ...

随机推荐

  1. JavaScript学习笔记之原型对象

    本文是学习<JavaScript高级程序设计>第六章的笔记. JS中,便于批量创建对象的三种模式: 1.工厂模式:用一个函数封装创建对象的细节,传入必要的参数,在函数内部new一个对象并返 ...

  2. 关于c:\fakepath\的解决办法

    (2014.11.25 最后更新) 一.碎碎念:关于访问本地图片的路径的问题,比较典型的例子就是上传头像.在以往的解决办法中,我们大多是先将图片上传到服务器然后从服务器返回图片,显示在页面上以达到预览 ...

  3. java常用指令

    javac 编译java源文件到字节码文件 -d XXX 1.指定编译后的字节码文件存放位置. 2.若编译的java源文件中使用包名,则根据包名生成相应的子目录 javac -d . Hello.ja ...

  4. nginx 跨域。。。掉坑里了,小心

    今天公司产品一个功能突然挂掉了...向客户演示之前出现了,手机端显示不能获取下载资源,可是急坏了一票人.. 通过手机端,调查服务器地址调用了http:/2342342.domain.hostname. ...

  5. Oracle数据库之rownum

    1. 介绍 当我们在做查询时,经常会遇到如查询限定行数或分页查询的需求,MySQL中可以使用LIMIT子句完成,在MSSQL中可以使用TOP子句完成,那么在Oracle中,我们如何实现呢? Oracl ...

  6. 原生Ajax + Promise

    有原生写的ajax + promise嫁接下 ;(function(root){ var LD = function(obj){ if( obj instanceof LD ) return obj; ...

  7. html5 DeviceOrientation来实现手机网站上的摇一摇功能

    原文地址:http://www.cootm.com/?p=706 从网上转载看到的,感觉不错,就转过来了,特此感谢 cnblogs 的 幸福2胖纸的码农生活,直接转载了,不要介意!呵呵 以下是转载内容 ...

  8. [ZHUAN]Flask学习记录之Flask-SQLAlchemy

    From: http://www.cnblogs.com/agmcs/p/4445583.html 各种查询方式:http://www.360doc.com/content/12/0608/11/93 ...

  9. Discuz!源代码阅读笔记之common.inc.php文件【1】

    <?php /* [Discuz!] (C)2001-2007 Comsenz Inc. This is NOT a freeware, use is subject to license te ...

  10. 解读为什么有符号的char可表示范围是-128~+127

    问:为什么有符号的char可表示范围是-128~+127? 要明白这个问题,首先要明白一下几点: 对于char和int计算机中以补码形式存在. 严格来说计算机就是傻逼,它只知道某个位上是0还是1. 我 ...