PHP通用分页(Pager)类

三种不同展示方式 附上style~

1. 效果图1

2.效果图2 

3. 效果图3

4. 分页类主体

<?php
/**
 * PHP通用分页类
 *
 * show(2) 1 ... 62 63 64 65 66 67 68 ... 150
 * 分页样式
 * #page{font:12px/16px arial}
 * #page span{float:left;margin:0px 3px;}
 * #page a{float:left;margin:0 3px;border:1px solid #ddd;padding:3px
 * 7px; text-decoration:none;color:#666}
 * #page a.now_page,#page a:hover{color:#fff;background:#05c}
 */
class Pager {
	public $first_row; //起始行数
	public $list_rows; //列表每页显示行数
	protected $total_pages; //总页数
	protected $total_rows; //总行数
	protected $now_page; //当前页数
	protected $method = ‘defalut‘; //处理情况 Ajax分页 Html分页(静态化时) 普通get方式
	protected $parameter = ‘‘;
	protected $page_name; //分页参数的名称
	protected $ajax_func_name;
	public $plus = 3; //分页偏移量
	protected $url;

	/**
	 * 构造函数
	 *
	 * @param unknown_type $data
	 */
	public function __construct($data = array()) {
		$this->total_rows = $data[‘total_rows‘];

		$this->parameter = !empty($data[‘parameter‘]) ? $data[‘parameter‘] : ‘‘;
		$this->list_rows = !empty($data[‘list_rows‘]) && $data[‘list_rows‘] <= 100 ? $data[‘list_rows‘] : 15;
		$this->total_pages = ceil($this->total_rows / $this->list_rows);
		$this->page_name = !empty($data[‘page_name‘]) ? $data[‘page_name‘] : ‘page‘;
		$this->ajax_func_name = !empty($data[‘ajax_func_name‘]) ? $data[‘ajax_func_name‘] : ‘‘;

		$this->method = !empty($data[‘method‘]) ? $data[‘method‘] : ‘‘;

		/* 当前页面 */
		if (!empty($data[‘now_page‘])) {
			$this->now_page = intval($data[‘now_page‘]);
		} else {
			$this->now_page = !empty($_GET[$this->page_name]) ? intval($_GET[$this->page_name]) : 1;
		}
		$this->now_page = $this->now_page <= 0 ? 1 : $this->now_page;

		if (!empty($this->total_pages) && $this->now_page > $this->total_pages) {
			$this->now_page = $this->total_pages;
		}
		$this->first_row = $this->list_rows * ($this->now_page - 1);
	}

	/**
	 * 得到当前连接
	 *
	 * @param
	 *        	$page
	 * @param
	 *        	$text
	 * @return string
	 */
	protected function _get_link($page, $text) {
		switch ($this->method) {
			case ‘ajax‘ :
				$parameter = ‘‘;
				if ($this->parameter) {
					$parameter = ‘,‘ . $this->parameter;
				}
				return ‘<a onclick="‘ . $this->ajax_func_name . ‘(‘‘ . $page . ‘‘‘ . $parameter . ‘)" href="javascript:void(0)">‘ . $text . ‘</a>‘ . "
";
				break;

			case ‘html‘ :
				$url = str_replace(‘?‘, $page, $this->parameter);
				return ‘<a href="‘ . $url . ‘">‘ . $text . ‘</a>‘ . "
";
				break;

			default :
				return ‘<a href="‘ . $this->_get_url($page) . ‘">‘ . $text . ‘</a>‘ . "
";
				break;
		}
	}

	/**
	 * 设置当前页面链接
	 */
	protected function _set_url() {
		$url = $_SERVER[‘REQUEST_URI‘] . (strpos($_SERVER[‘REQUEST_URI‘], ‘?‘) ? ‘‘ : "?") . $this->parameter;
		$parse = parse_url($url);
		if (isset($parse[‘query‘])) {
			parse_str($parse[‘query‘], $params);
			unset($params[$this->page_name]);
			$url = $parse[‘path‘] . ‘?‘ . http_build_query($params);
		}
		if (!empty($params)) {
			$url .= ‘&‘;
		}
		$this->url = $url;
	}

	/**
	 * 得到$page的url
	 *
	 * @param $page 页面
	 * @return string
	 */
	protected function _get_url($page) {
		if ($this->url === NULL) {
			$this->_set_url();
		}
		//	$lable = strpos(‘&‘, $this->url) === FALSE ? ‘‘ : ‘&‘;
		return $this->url . $this->page_name . ‘=‘ . $page;
	}

	/**
	 * 得到第一页
	 *
	 * @return string
	 */
	public function first_page($name = ‘第一页‘) {
		if ($this->now_page > 5) {
			return $this->_get_link(‘1‘, $name);
		}
		return ‘‘;
	}

	/**
	 * 最后一页
	 *
	 * @param
	 *        	$name
	 * @return string
	 */
	public function last_page($name = ‘最后一页‘) {
		if ($this->now_page < $this->total_pages - 5) {
			return $this->_get_link($this->total_pages, $name);
		}
		return ‘‘;
	}

	/**
	 * 上一页
	 *
	 * @return string
	 */
	public function up_page($name = ‘上一页‘) {
		if ($this->now_page != 1) {
			return $this->_get_link($this->now_page - 1, $name);
		}
		return ‘‘;
	}

	/**
	 * 下一页
	 *
	 * @return string
	 */
	public function down_page($name = ‘下一页‘) {
		if ($this->now_page < $this->total_pages) {
			return $this->_get_link($this->now_page + 1, $name);
		}
		return ‘‘;
	}

	/**
	 * 分页样式输出
	 *
	 * @param
	 *        	$param
	 * @return string
	 */
	public function show($param = 1) {
		if ($this->total_rows < 1) {
			return ‘‘;
		}

		$className = ‘show_‘ . $param;

		$classNames = get_class_methods($this);

		if (in_array($className, $classNames)) {
			return $this->$className();
		}
		return ‘‘;
	}

	protected function show_2() {
		if ($this->total_pages != 1) {
			$return = ‘‘;
			$return .= $this->up_page(‘<‘);
			for ($i = 1; $i <= $this->total_pages; $i++) {
				if ($i == $this->now_page) {
					$return .= "<a class=‘now_page‘>$i</a>
";
				} else {
					if ($this->now_page - $i >= 4 && $i != 1) {
						$return .= "<span class=‘pageMore‘>...</span>
";
						$i = $this->now_page - 3;
					} else {
						if ($i >= $this->now_page + 5 && $i != $this->total_pages) {
							$return .= "<span>...</span>
";
							$i = $this->total_pages;
						}
						$return .= $this->_get_link($i, $i) . "
";
					}
				}
			}
			$return .= $this->down_page(‘>‘);
			return $return;
		}
	}

	protected function show_1() {
		$plus = $this->plus;
		if ($plus + $this->now_page > $this->total_pages) {
			$begin = $this->total_pages - $plus * 2;
		} else {
			$begin = $this->now_page - $plus;
		}

		$begin = ($begin >= 1) ? $begin : 1;
		$return = ‘‘;
		$return .= $this->first_page();
		$return .= $this->up_page();
		for ($i = $begin; $i <= $begin + $plus * 2; $i++) {
			if ($i > $this->total_pages) {
				break;
			}
			if ($i == $this->now_page) {
				$return .= "<a class=‘now_page‘>$i</a>
";
			} else {
				$return .= $this->_get_link($i, $i) . "
";
			}
		}
		$return .= $this->down_page();
		$return .= $this->last_page();
		return $return;
	}

	protected function show_3() {
		$plus = $this->plus;
		if ($plus + $this->now_page > $this->total_pages) {
			$begin = $this->total_pages - $plus * 2;
		} else {
			$begin = $this->now_page - $plus;
		}
		$begin = ($begin >= 1) ? $begin : 1;
		$return = ‘总计 ‘ . $this->total_rows . ‘ 个记录分为 ‘ . $this->total_pages . ‘ 页, 当前第 ‘ . $this->now_page . ‘ 页 ‘;
		$return .= ‘,每页 ‘;
		$return .= ‘<input type="text" value="‘ . $this->list_rows . ‘" id="pageSize" size="3"> ‘;
		$return .= $this->first_page() . "
";
		$return .= $this->up_page() . "
";
		$return .= $this->down_page() . "
";
		$return .= $this->last_page() . "
";
		$return .= ‘<select onchange="‘ . $this->ajax_func_name . ‘(this.value)" id="gotoPage">‘;

		for ($i = $begin; $i <= $begin + 10; $i++) {
			if ($i > $this->total_pages) {
				break;
			}
			if ($i == $this->now_page) {
				$return .= ‘<option selected="true" value="‘ . $i . ‘">‘ . $i . ‘</option>‘;
			} else {
				$return .= ‘<option value="‘ . $i . ‘">‘ . $i . ‘</option>‘;
			}
		}
		$return .= ‘</select>‘;
		return $return;
	}
}

?>

5.使用方法

###处理html静态化页面分页的情况###
# method 处理环境 设置为 html
# parameter 为静态页面参数  xxx.com/20-0-0-0-40-?.html 注意问号
# ?问号的位置会自动替换为去向页码
# now_page 当前页面(静态页面获取不到当前页面所以只有你传入)
$params = array(
			‘total_rows‘=>100, #(必须)
			‘method‘    =>‘html‘, #(必须)
			‘parameter‘ =>‘xxx.com/20-0-0-0-40-?.html‘,  #(必须)
			‘now_page‘  =>$_GET[‘p‘],  #(必须)
			‘list_rows‘ =>10, #(可选) 默认为15
);
$page = new Pager($params);
   echo  $page->show(1);
   #<a href="xxx.com/20-0-0-0-40-2.html">2</a>

###处理ajax分页的情况###
# method 处理环境 设置为 ajax
# ajax_func_name ajax分页跳转页面的javascript方法
# parameter    ajax_func_name后面的附带参数 默认为空
# now_page 不到当前页面所以只有你传入
$params = array(
			‘total_rows‘=>100,
			‘method‘    =>‘ajax‘,
			‘ajax_func_name‘ =>‘goToPage‘,
			‘now_page‘  =>1,
			#‘parameter‘ =>"‘jiong‘,‘username‘",
);
$page = new Pager($params);
   echo  $page->show(1);
#<a href="javascript:void(0)" onclick="goToPage(‘7‘)">7</a>
#添加了parameter<a href="javascript:void(0)" onclick="goToPage(‘6‘,‘jiong‘,‘username‘)">6</a>
时间: 2024-10-10 02:14:45

PHP通用分页(Pager)类的相关文章

通用分页工具类

一.本工具与数据库.框架.展现层无关.代码如下: /** * 用于分页的工具类 */ public class Pager<T> { private List<T> list = new ArrayList<T>(); //对象记录结果集 private int total = 0; // 总记录数 private int pageSize = 10; // 每页显示记录数 private int pageCount = 1; // 总页数 private int pa

通用分页请求返回类

using System.Runtime.Serialization; /// <summary> /// 通用分页请求类 /// </summary> [DataContract] public class PagedListModelReq : Request { /// <summary> /// <strong>Initializes a new instance of the <see cref="</strong>Op

asp.net mvc 简易通用自定义Pager实现分页

asp.net mvc 简易通用自定义Pager实现分页 Intro 一个WEB应用程序中经常会用到数据分页,本文将实现一个简单通用的分页组件,包含一个 PagerModel (用来保存页码信息),一个 HtmlHelper 的 Pager 扩展方法和一个 PagedListModel<T> 分页数据模型. PagerModel 分页模型 PagerModel 用来保存分页信息,代码实现如下: 1 /// <summary> 2 /// PagerModel 分页模型 3 ///

ibernate学习笔记5---实体类或属性名与数据库关键字冲突、hql命名参数、hql实现通用分页

一.实体类或属性名与数据库关键字冲突问题1.实体类名与数据库中的关键字冲突比如:实体表User与oracle中的系统表冲突解决方式1:在xml中添加table属性,指定表名,使其不与name默认相等 [html] view plaincopyprint? <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hiber

通用Hibernate DAO类(包括分页)

package com.jronline.dao; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.List; import org.hibernate.HibernateException; import org.hibernate.Query; import org.hibernate.SQLQuery; import org.hibern

一个通用分页类

1.功能 这个通用分页类实现的功能是输入页数(第几页)和每页的数目,就能获得相应的数据. 2.实现原理 分页的实现通常分为两种,一种是先把数据全查询出来再分页,一种是需要多少查询多少,这里使用第二种,所以就需要先实现在dao层能够查询一定范围内的数据,这里就实现通过id作为键值,查询一定范围内的数据的功能 dao层需要实现一个返回id在一个范围内的数据,那就在dao层的接口中添加一个这个方法: List<User> selectByRange(@Param("low") I

JS 通用分页

1 //上一页 2 function nextPager(href, pageindex, pagecount) { 3 4 if (pageindex > pagecount) { 5 pageindex = pagecount; 6 } else { 7 pageindex = pageindex + 1; 8 } 9 pager(href, pageindex); 10 } 11 //下一页 12 function upPager(href, pageindex) { 13 14 if (

利用EF和C#泛型实现通用分页查询

利用EF和C#泛型实现通用分页查询 Entity Framework 是微软以 ADO.NET 为基础所发展出来的对象关系对应 (ORM) 解决方案,是微软的ORM框架.此框架将数据库中的表信息通过xml与实体类对象相关联,使得开发人员只需要关心实体对象,而不需要手动操作数据库,对实体对象的修改会映射到数据库中,这样大大提高了开发效率.以下代码使用了EF.泛型.泛型委托.lambda.匿名类.dynamic动态类型等知识完成了EF的crud,并且提供了一个高效的通用分页查询方法,采用了延时加载,

通用分页1

通用分页 首先你得先把数据库连上(由于数据库不同,就不做演示了) 然后就是准备一个判断字符串得类 StringUtils类 public class StringUtils { // 私有的构造方法,保护此类不能在外部实例化 private StringUtils() { } /** * 如果字符串等于null或去空格后等于"",则返回true,否则返回false * * @param s * @return */ public static boolean isBlank(Strin