PHP开发-分页实现(附效果图)

原创 2013年12月03日 21:51:37

首先一个分页类,如下(摘自网络)可拷贝直接使用

<?php
/*
 * Created on 2013-12-3
 * 分页类
 * To change the template for this generated file go to
 * Window - Preferences - PHPeclipse - PHP - Code Templates
 */
class Pagination {
	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) {
		$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 . "  ";
			} 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文件中

include_once ("Pagination.php");
//每页显示的条数
$pageSize = 10;
//总条目数
$pageTotal = $db->get_var("select count(*) from tb");
//每次显示的页数
$sub_pages = 10;
//得到当前是第几页
if (is_array($_GET) && count($_GET) > 0) {
	if (isset ($_GET["p"])) { //是否存在"id"的参数
		$pageCurrent = $_GET["p"];
	}
} else {
	$pageCurrent = 1;
}
$goodses = $db->get_results("SELECT g.id,* FROM tb as g INNER JOIN (select id from tb  order by updatetime desc limit " . ($pageCurrent -1) * $pageSize . ",10 )as g1 ON g.id=g1.id");

显示分页数据

<?php $subPages = new Pagination($pageSize, $pageTotal, $pageCurrent, $sub_pages, "index.php?p=", 2);?>

效果图:

注:本文的Pagination类来自网络,没有标注网址,在原代码的基础上进行了修改,如果涉及任何问题,请留言。在此感谢作者,并作出上述声明。

转载请注明出处:http://blog.csdn.net/tangcheng_ok


相关文章推荐

php分页代码简单实现

php分页代码简单实现
  • jsship
  • jsship
  • 2014年11月19日 21:42
  • 21665

php+mysql实现分页:上一页,下一页

mysql里将数据分页显示的语句是:limit  5,1。5表示检索开始位置,1表示显示1页 所以在php中要实现上一页,下一页就要传一个数据page给limit,就可以分页。 可以理解为三个步骤: ...

PHP简单漂亮的分页类

文介绍一款原生的PHP分页类,分页样式有点类似bootstrap。 index.php代码

PHP分页原理+代码实现

PHP分页原理 Mysql分页查询Limit关键字 sql语句 select * from table_name limit a,b; limit a,b 代表从第a条数据开始,查询总共b...

PHP实现分页功能

综合了很多技术大牛的经验,然后做出了一个真正可以实现的代码,功能是在查询后,可以做到分页,点击下一页后依然可以保持原来的查询语句继续执行。...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

php带省略号的分页

PHP数据分页显示详细讲解

PHP数据分页显示详细讲解 转载:https://www.douban.com/note/318155134/ php爱好者专刊之php数据分页显示 php爱好者 1、前言 分页显示是一种非常常...

php简单的分页原理

运用php来实现分页原理解析, 下边我以用户表的例子讲解下。 //获取此时你要显示的是第几页 $page =$_GET['p'];  $pageSize=9;//每页显示数据的个数 $...

PHP自动适应范围的页码分页程序

记得以前看过一个页码方式的分页效果,页码数多了折行继续显示一直到60多页,呵呵!有点影响美观! 于是写了一个,可以自动适应范围的页码分页程序 也就是说,页码格式如下 >> >> ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PHP开发-分页实现(附效果图)
举报原因:
原因补充:

(最多只允许输入30个字)