php分页方法
来源:互联网 发布:皇帝龙根插知画 编辑:程序博客网 时间:2024/04/29 22:54
第一步创建一个类 subPages.php
<?php
class SubPages{
private $each_disNums;//每页显示的条目数
private $nums;//总条目数
private $current_page;//当前被选中的页
private $sub_pages;//每次显示的页数
private $pageNums;//总页数
private $page_array = array();//用来构造分页的数组
private $subPage_link;//每个分页的链接
private $subPage_type;//显示分页的类型
//__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,$subPage_type){
//intval通过使用特定的进制转换(默认是十进制),返回变量 var 的 integer 数值
$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;
$this->show_SubPages($subPage_type);
//echo $this->pageNums."--".$this->sub_pages;
}
//__destruct析构函数,当类不在使用的时候调用,该函数用来释放资源
function __destruct(){
unset($each_disNums);
unset($nums);
unset($current_page);
unset($sub_pages);
unset($pageNums);
unset($page_array);
unset($subPage_link);
unset($subPage_type);
}
//show_SubPages函数用在构造函数里面。而且用来判断显示什么样子的分页
function show_SubPages($subPage_type){
if($subPage_type == 1){
$this->subPageCss1();
}elseif ($subPage_type == 2){
$this->subPageCss2();
}
}
//用来给建立分页的数组初始化的函数。
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.="[尾页] ";
}
echo $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.="[尾页] ";
}
echo $subPageCss2Str;
}
}
?>
要做分页的页面
<?php
//每页显示的条数
$page_size=2;
//得到当前是第几页
$pageCurrent=$_GET["p"];
$offet =($pageCurrent-1)*$page_size;
//建立数据库连接
$conn = mysql_connect("地址","用户名","密码") or die("".mysql_error());
//设置字符集
mysql_query("set names gbk");
//设置数据库
mysql_select_db("数据库名",$conn) or die("".mysql_error());
if($conn) {
include ("query.html");
//查询会员信息
//注:这里的sql查询了两遍.第一遍是确定查询出来的总数据条数
$query_sql = "SELECT * FROM user_info_t order by id desc";
//第二遍是根据需要即$page_size来确定每次查出的条数
$query_sql_sec= "SELECT * FROM user_info_t order by id desc limit $offet,$page_size";
//执行查询语句 返回一个结果集
$query_res = mysql_query($query_sql,$conn);
$query_res_sec = mysql_query($query_sql_sec,$conn);
//查询列数
//$query_cols = mysql_num_fields($query_res);
//查询行数
$query_num =mysql_num_rows($query_res);
//返回根据从结果集取得的行生成的数组,如果没有更多行
echo "<table border='0' cellpadding='1' cellspacing='2' width='100%' bgcolor='#FFFFFF'>";
while($query_row = mysql_fetch_array($query_res_sec)) {
echo "<tr>";
for ($i=0;$i<$query_cols;$i++) {
echo "<td bordercolor='#A2BEE1' bgcolor='#A2BEE1' width='8%'>".$query_row[$i]."</td>/n";
}
echo "<td bordercolor='#A2BEE1' bgcolor='#A2BEE1' width='8%'>";
//echo "<input type='button' class='button' id='modify_record' name='modify_record' value='修改' />";
echo "<button onClick=/"submit(location.href ='../modify/modify.php?rec_id=$query_row[0]');/" class=/"button/";>修改</button>";
//echo "<a href='../delete/delete.php?rec_id=$query_row[0]' onClick=/"if(confirm('确实要删除此条记录吗?')) return true;else return false;/"><img src=/"../image/delete.gif/" align=/"absmiddle/" />删除</a>";
echo "<button onClick=/"if(confirm('确实要删除此条记录吗?')) return submit(location.href ='../delete/delete.php?rec_id=$query_row[0]');else return false;/" class=/"button/";>删除</button>";
echo "</td>";
echo "</tr>";
}
//echo "</form>";
echo "</table>";
require_once("../common/subPages.php");
//总条目数为数据库中查询出的数据条数
$nums=$query_num;
//每次显示的页数
$sub_pages=10;
//if(!$pageCurrent) $pageCurrent=1;
//调用类SubPages 传的参数为:每页显示条数/当前第几页/每次显示的页数/分页模式
$subPage=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"query.php?p=",1);
}else{
die('数据库连接异常: '.mysql_error());
}
//断开数据库连接
if ($conn)
{
mysql_close($conn);
}
?>
- php分页实现方法
- php分页方法
- PHP分页方法
- php分页方法--转载
- PHP分页方法和分页类
- php生成静态html分页实现方法
- PHP+MySQL实现分页的常用方法
- php最简单MYSQL分页显示方法
- php最简单MYSQL分页显示方法
- PHP array_slice() 数组分页的实现方法
- php数组方法+排序分页问题
- php怎么写分页?怎么灵活实现分页的方法,快速在thinkphp里面实现分页
- php分页
- php:分页
- PHP 分页
- php分页
- PHP分页
- php分页.....
- ASP.net的代码模型
- 字幕:《李开复谈创新思维》上
- 不容易阿,终于到这个函数了write_packet
- 半导体特征循环与可重构芯片
- 01背包问题---C源程序
- php分页方法
- 基于可编程处理器的H.264技术的实现
- 用SAS读入原始数据(1):文本文件 的四种格式
- 在ASP.NET中使用Session常见问题集锦
- C#类和接口、虚方法和抽象方法及值类型和引用类型的区别(转)
- java文件操作【列出指定目录下的文件】
- input set 时遇到地问题
- java线程测试, JDK1.6的发现 (求探讨)
- 常用asp.net代码