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 int $page
* @param string $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 string $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 '';
} /**
* 上一页
*
* @param string $name
* @return string
*/
public function up_page($name = '上一页')
{
if ($this->now_page != 1)
{
return $this->_get_link($this->now_page - 1, $name);
} return '';
} /**
* 下一页
*
* @param sring $name
* @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>
PHP通用分页(Pager)类的更多相关文章
- asp.net mvc 简易通用自定义Pager实现分页
asp.net mvc 自定义Pager实现分页 Intro 一个WEB应用程序中经常会用到数据分页,本文将实现一个简单通用的分页组件,包含一个 PagerModel (用来保存页码信息),一个 Ht ...
- ibernate学习笔记5---实体类或属性名与数据库关键字冲突、hql命名参数、hql实现通用分页
一.实体类或属性名与数据库关键字冲突问题1.实体类名与数据库中的关键字冲突比如:实体表User与oracle中的系统表冲突解决方式1:在xml中添加table属性,指定表名,使其不与name默认相等 ...
- 【转】通用分页用户控件(DataGrid,DataList,Repeater都可以用它来分页)
通用分页控件(DataGrid,DataList,Repeater都可以用它来分页) 1.建立用户控件Pager.ascx 1.1 html </ASP:LABEL></TD> ...
- Spring Boot mybatis HashMap +layui 通用分页
背景: mybatis 常用数据查询的方法都是先建实体类,再建Mapper,最后写Service,如果只是单纯的去查询数据显示,这样操作太麻烦.本文就以mybatis +layui创建通用分页类,简化 ...
- 利用EF和C#泛型实现通用分页查询
利用EF和C#泛型实现通用分页查询 Entity Framework 是微软以 ADO.NET 为基础所发展出来的对象关系对应 (ORM) 解决方案,是微软的ORM框架.此框架将数据库中的 ...
- C#简单的通用分页
通用分页技术分析 需要返回不同的类型的数据--采用泛型实现该操作 需要提供不同的方法 上一页 上一页 第一页 最后一页 跳转到指定页 Demo 代码 using System; using Syste ...
- liferay总结的通用的工具类
在写增删改查的时候,自己动手写了几个通用的工具类,这几个通用的工具类也是基于API写的 第一个是liferay中的分页.跟我们做普通的web开发,分页是一样的首先需要建立一个分页的实体的类 packa ...
- 通用分页jsp页面显示
注:本章内容都是在上一篇文章 通用分页后台显示:https://www.cnblogs.com/ly-0919/p/11058942.html 的基础上进行改进,所以有许多的类都在上一篇, 带来不便 ...
- dapper通用分页方法
/// <summary> /// dapper通用分页方法 /// </summary> /// <typeparam name="T">泛型 ...
随机推荐
- hibernate inverse属性的作用
hibernate配置文件中有这么一个属性inverse,它是用来指定关联的控制方的.inverse属性默认是false,若为false,则关联由自己控制,若为true,则关联由对方控制.见例子: 一 ...
- Spring整合Redis
1.相关jar包 除了Spring必须的jar外,还需要spring-data-redis,jedis,commons-pool,这里使用的是maven,也可以拿着url把jar包下下来 <!- ...
- Mysql优化系列(2)--通用化操作梳理
前面有两篇文章详细介绍了mysql优化举措:Mysql优化系列(0)--总结性梳理Mysql优化系列(1)--Innodb引擎下mysql自身配置优化 下面分类罗列下Mysql性能优化的一些技巧,熟练 ...
- TEXTAREA自适应文字行数的多少
<textarea rows=1 name=s1 cols=27 onpropertychange="this.style.posHeight=this.scrollHeight&qu ...
- 解决Firefox/Opera 不支持onselectstart事件实现不允许用户select
在IE/Safari/Chrome中我们可以使用onselectstart事件来阻止用户选定元素内文本,本文为大家解决下火狐中如何实现不能选择,由此需求的朋友可以参考下,希望对大家有所帮助 ...
- knockoutJS学习笔记07:绑定上下文
所谓绑定上下文就是当前绑定(dat-bind)所使用到的对象(ViewModel).在单个对象绑定的情况下是很容易理解的,但对象可能是复杂的类型,嵌套很多层,这个时候每层都有自己的上下文对象,理解起来 ...
- 尝试使用Memcached遇到的狗血问题
乘着有时间,尝试下利用Memcached进行分布式缓存,其中遇到了不少问题及狗血的事情,开篇记录下,希望对您有帮助. 我之前的项目为:Asp.Net MVC4 + Nhibernate + MSSQL ...
- 如何在Excel中通过VBA快速查找多列重复的值
今天项目组的一个同事问我如何快速的找到一个Excel中第3列和第5列的值完全重复的值,我想了想虽然Excel中自带查找重复值的功能,但是好像只能对同一列进行比较,所以就写了一个VBA进行处理,VBA非 ...
- 编译安装php7
yum install libxml2-devel curl-devel openjpeg openjpeg-devel openjpeg-libs libjpeg libpng freetype l ...
- sp_executeSql 用法
今天遇到了一个难题 就是把 一个拼接sql语句 的返回值 赋值给一个变量 经研究 要用sp_executeSql这个存储过程 据说是从sql 2005才开始有的 代码如下: declare @str ...