功能强大的php分页函数

分页是每一个程序需要去理解的东西,学习过的几门语言中我发现分页原理都是一样的,下面为php初学者分析一下php分页实现与最后面补充了一个超级强大的分页函数。

文章内容分页主要有两个办法:

办法一、按字数控制进行分页

按字数分页办法简单易用,但效果不好.

大致思想:首先、设定每页能容纳的最大字数,然后、计算文章内容的总字数,再由总字数和单页最大字数计算出出总页数,这样整个分页的准备工作就已经做好了.

具体到每一页的显示内容可以通过内容截取来实现,比如:页容纳500字,文章内容有2200字,那么当页面传递page=2时应该显示第501至1000之间的内容.

这种办法简单,但显示时可能会遇到麻烦,文章内容通常伴有HTML标签,进行内容切割时实现HTML标签的闭合有一定难度,如果这个工作没做好,那么分页后的效果显然也是不好的.

办法二、通过分页符进行分页

通过分页符进行分页比起第一种办法要更为理想。

大致思想:在编辑文章内容时往内容里面插入分页符(如:<hr class="page">),在文章显示时对文章内容进行分割,每一部分表示一个页的内容,通过传递参数控制显示第几页。

这种办法比较人性化,毕竟通过人工控制出来的分页截取的内容更符全我们的思维,而且可以一定程度上避免HTML标签不闭合的情形。

分页显示:分页显示是将大批量的数据分批发送到客户端的重要手段之一,通常是将数据库中的结果集人为的分成一段一段的来显示.

分类:PHP分页分为列表分页内容分页,不管是列表分页还是内容分页,基本原理是一样的,将数据分批发送到客户端.

pager.class.php:这是一个简单的PHP分页显示类,目前支持两种分页模式,一种是最简单的普通分页模式[首页] [上页] [下页] [尾页]模式,另一种是经典分页模式,即:[1][2][3][4][5][6][7][8][9][10][下一页][尾页].

使用方法,代码如下:

require_once 'pager.class.php';
$pager = new pager($totalPage,$currentPage); // $pager对象
echo $pager->showpager(); // 输出分页
此分页显示类的构造函数
/*
@total_page 总页数
@current_num 当前页
@sub_pages 每次显示的页数
@subPage_link 每个分页的链接
@subPage_type 分页模式
当@subPage_type=1的时候为普通分页模式
如: 共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [下页] [尾页]
当@subPage_type=2的时候为经典分页样式
如: 当前第1/453页 [首页] [上页] 1 2 3 4 5 6 7 8 9 10 [下页] [尾页]
*/ 

代码如下:

pager($total_page,$current_page,$sub_pages=10,$subPage_link='',$subPage_type=2)

上述说的PHP分页的两种类别(列表分页和内容分页),相信列表分页对大家并不陌生,对于内容分页,常用的方法是以分页符的形式(比如: <hr class="pager"> )将内容分割成多段,求出总页数,用当前页码去获取分页显示列表,代码如下:

<?php
/**
 * 示例:
 * <?php
 * require_once("pager.class.php");
 * $subPages=new pager($totalPage,$currentPage);
 * echo $subPages->showpager();
 * ?>
 * */
class pager{
 var $each_disNums;//每页显示的条目数
 var $nums;//总条目数
 var $current_page;//当前被选中的页
 var $sub_pages;//每次显示的页数
 var $pageNums;//总页数
 var $page_array = array();//用来构造分页的数组
 var $subPage_link;//每个分页的链接
 var $subPage_type;//显示分页的类型
 var $_lang = array(
 'index_page' => '首页',
 'pre_page' => '上一页',
 'next_page' => '下一页',
 'last_page' => '尾页',
 'current_page' => '当前页:',
 'total_page' => '总页数:',
 'current_show' => '当前显示:',
 'total_record' => '总记录数:'
 );
 /*
 __construct是SubPages的构造函数,用来在创建类的时候自动运行.
 @total_page 总页数
 @current_num 当前被选中的页
 @sub_pages 每次显示的页数
 @subPage_link 每个分页的链接
 @subPage_type 显示分页的类型 

 当@subPage_type=1的时候 www.phpfensi.com 为普通分页模式
 example: 共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [下页] [尾页]
 当@subPage_type=2的时候为经典分页样式
 example: 当前第1/453页 [首页] [上页] 1 2 3 4 5 6 7 8 9 10 [下页] [尾页]
 */
 function __construct($total_page,$current_page,$sub_pages=10,$subPage_link='',$subPage_type=2){
 $this->pager($total_page,$current_page,$sub_pages,$subPage_link,$subPage_type);
 } 

 function pager($total_page,$current_page,$sub_pages=10,$subPage_link='',$subPage_type=2){
 if(!$current_page){
 $this->current_page=1;
 }else{
 $this->current_page=intval($current_page);
 }
 $this->sub_pages=intval($sub_pages);
 $this->pageNums=ceil($total_page);
 if($subPage_link){
 if(strpos($subPage_link,'?page=') === false AND strpos($subPage_link,'&page=') === false){
 $subPage_link .= (strpos($subPage_link,'?') === false ? '?' : '&') . 'page=';
 }
 }
 $this->subPage_link=$subPage_link ? $subPage_link : $_SERVER['PHP_SELF'] . '?page=';
 $this->subPage_type = $subPage_type;
 } 

 /*
 show_SubPages函数用在构造函数里面。而且用来判断显示什么样子的分页
 */
 function showpager(){
 if($this->subPage_type == 1){
 return $this->pagelist1();
 }elseif ($this->subPage_type == 2){
 return $this->pagelist2();
 }
 } 

 /*
 用来给建立分页的数组初始化的函数。
 */
 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 pagelist1(){
 $subPageCss1Str="";
 $subPageCss1Str.= $this->_lang['current_page'] . $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'>{$this->_lang['index_page']}</a> ";
 $subPageCss1Str.="<a href='$prewPageUrl'>{$this->_lang['pre_page']}</a> ";
 }else {
 $subPageCss1Str.="{$this->_lang['index_page']} ";
 $subPageCss1Str.="{$this->_lang['pre_page']} ";
 } 

 if($this->current_page < $this->pageNums){
 $lastPageUrl=$this->subPage_link.$this->pageNums;
 $nextPageUrl=$this->subPage_link.($this->current_page+1);
 $subPageCss1Str.=" <a href='$nextPageUrl'>{$this->_lang['next_page']}</a> ";
 $subPageCss1Str.="<a href='$lastPageUrl'>{$this->_lang['last_page']}</a> ";
 }else {
 $subPageCss1Str.="{$this->_lang['next_page']} ";
 $subPageCss1Str.="{$this->_lang['last_page']} ";
 } 

 return $subPageCss1Str;
 } 

 /*
 构造经典模式分页
 当前第1/453页 [首页] [上页] 1 2 3 4 5 6 7 8 9 10 [下页] [尾页]
 */
 function pagelist2(){
 $subPageCss2Str="";
 $subPageCss2Str.=$this->_lang['current_page'] . $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'>{$this->_lang['index_page']}</a> ";
 $subPageCss2Str.="<a href='$prewPageUrl'>{$this->_lang['pre_page']}</a> ";
 }else {
 $subPageCss2Str.="{$this->_lang['index_page']} ";
 $subPageCss2Str.="{$this->_lang['pre_page']} ";
 } 

 $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'>{$this->_lang['next_page']}</a> ";
 $subPageCss2Str.="<a href='$lastPageUrl'>{$this->_lang['last_page']}</a> ";
 }else {
 $subPageCss2Str.="{$this->_lang['next_page']} ";
 $subPageCss2Str.="{$this->_lang['last_page']} ";
 }
 return $subPageCss2Str;
 } 

 /*
 __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);
 }
}
?>

好了我们只要把它保存在一个文件,在其它地方要使用时直接调用就可以了,非常好用的一个内容或记录分页类函数哦,这也算是一个入门级别的php教程吧。

精彩专题分享:php分页功能

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • php+ajax实现无刷新分页

    本文实例讲述了php+ajax实现无刷新分页实现方法.分享给大家供大家参考.具体如下:     limit  偏移量,长度;     limit  0,7;   第一页     limit  7,7;   第二页     limit  14,7;  第三页 每页信息条数:7 信息总条数:select count(*) from table 信息总页数:ceil向上取整(总条数/每页条数) 1.分页类具体使用 <?php class Pagination { private $total; //数

  • PHP框架Laravel插件Pagination实现自定义分页

    Laravel 的分页很方便,其实扩展起来也挺容易的,下面就来做个示例,扩展一下 paginate() 和 simplePaginate() 方法,来实现我们自定义分页样式,比如显示 "上一页" 和 "下一页" ,而不是 "<" 和 ">" ,当然扩展的方法掌握了你就可以肆无忌惮的扩展一个你想要的分页了,比如跳转到某一页,分页显示一共多少记录,当前显示的记录范围等等巴拉巴拉的... 5.1和5.2应该是同样的方法,

  • php实现分页功能的3种方法第1/3页

    直接上代码,希望大家仔细阅读. 方法一:讲sql查询进行分页进行,需要调用几个函数,具体见脚本: 1.pager.class.php <?php class pager { public $sql; //SQL查询语句 public $datanum; //查询所有的数据总记录数 public $page_size; //每页显示记录的条数 protected $_errstr; protected $_conn; protected $_query_id; public function qu

  • 两款万能的php分页类

    本文为大家分享个超级好用.万能的php分页类,具体的实现代码如下 第一款php分页类 <?php /* * To change this template, choose Tools | Templates * and open the template in the editor. */ /** * 分页类 * 使用方式: * $page = new Page(); * $page->init(1000, 20); * $page->setNotActiveTemplate('<

  • 基于PHP实现数据分页显示功能

    本文实例为大家分享了数据分页显示功能的PHP实现代码,供大家参考,具体内容如下 实现代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>用户列表</title> </head> <body> <?php $con = mysql_connect("localhost","root&

  • php分页原理 分页代码 分页类制作教程

    分页显示是一种非常常见的浏览和显示大量数据的方法,属于web编程中最常处理的事件之一.对于web编程的老手来说,编写这种代码实在是和呼吸一样自然,但是对于初学者来说,常常对这个问题摸不着头绪,因此特地撰写此文对这个问题进行详细的讲解. 一.分页原理: 所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数: 每页多少条记录($PageSize)?        当前是第几页($CurrentPageID)? 现在只要再给我一个结果集,我就可以显示某段特定的结果出

  • PHP MSSQL 分页实例

    本文实例为大家分享了PHP MSSQL可刷新分页实例,具体内容如下 <?php /* '页面说明: */ $link=mssql_connect("MYSQL2005","sa","123456") or die("db link error!".mssql_error()); mssql_select_db("edu_dzk",$link) or die("db open error!&q

  • 功能强大的php分页函数

    分页是每一个程序需要去理解的东西,学习过的几门语言中我发现分页原理都是一样的,下面为php初学者分析一下php分页实现与最后面补充了一个超级强大的分页函数. 文章内容分页主要有两个办法: 办法一.按字数控制进行分页 按字数分页办法简单易用,但效果不好. 大致思想:首先.设定每页能容纳的最大字数,然后.计算文章内容的总字数,再由总字数和单页最大字数计算出出总页数,这样整个分页的准备工作就已经做好了. 具体到每一页的显示内容可以通过内容截取来实现,比如:页容纳500字,文章内容有2200字,那么当页

  • PHP中功能强大却很少使用的函数实例小结

    本文实例讲述了PHP中功能强大却很少使用的函数.分享给大家供大家参考,具体如下: call_user_func_array - 让参数以数组的形式调用一个函数 call_user_func - 调用一个存在的函数 create_function - 建立一个函数 func_get_arg - 获取函数中某个参数的值 func_get_args - 获取函数的所有参数并组成数组 func_num_args - 获取一个函数的参数个数 function_exists - 判定一个函数是否存在 get

  • asp.net(C#)实现功能强大的时间日期处理类完整实例

    本文实例讲述了asp.net(C#)实现功能强大的时间日期处理类.分享给大家供大家参考,具体如下: using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts

  • Asp.Net实现的通用分页函数

    本文实例讲述了Asp.Net实现的通用分页函数.分享给大家供大家参考,具体如下: 功能: 1.每页设置显示9页,超过9页,点5页后的+1页显示(可以随便修改) 2.CSS样式自己可以设置 3.无任何咋代码产生,利于搜索引擎优化 分页程序 objPDS = new PagedDataSource(); objPDS.DataSource = dtTable.DefaultView;//绑定数据源 objPDS.AllowPaging = true; objPDS.PageSize =10;//分页

  • PHP基于数组实现的分页函数实例

    分页功能是PHP程序设计中非常常见的功能,不同于以往的,今天本文介绍的是PHP基于数组实现的分页函数. 关于数组的分页函数,用数组进行分页的好处是可以方便的进行联合多表查询,只需要将查询的结果放在数组中就可以了以下是数组分页的函数,函数page_array用于数组的分页,函数show_array用于分页函数的操作及显示,需要配合使用.两个函数通过全局变量$countpage发生联系,此变量用于跟踪总页码数. 具体实例代码如下: <?php /** * 数组分页函数 核心函数 array_slic

  • 打造个性化的功能强大的Jquery虚拟键盘(VirtualKeyboard)

    最近做项目,我负责做网页前端,客户需要利用触摸屏进行操作,不外接鼠标键盘,但要求能录入文字,包括数字,英文,中文.思考了一下,决定用JS实现虚拟键盘. 首先上网搜索了一下JS虚拟键盘,在经过仔细筛选后,相中了VirtualKeyboard,一款功能强大的JS虚拟键盘插件. 先简单介绍一下VirtualKeyboard,它内置了100多种键盘布局和200多种输入法,9套可选皮肤方案,而且支持自建输入法,功能相当强大. 先附上下载地址,目前的最新版本3.94:http://www.coralloso

  • php分页函数完整实例代码

    本文分享一例php分页函数完整实例代码,使用此函数实现分页效果很不错.分享给大家供大家参考. 具体功能代码如下: <?php /* * Created on 2011-07-28 * 使用方法: require_once('mypage.php'); $result=mysql_query("select * from mytable", $myconn); $total=mysql_num_rows($result); //取得信息总数 pageDivide($total,10

  • redux功能强大的Middleware中间件使用学习

    目录 引言 redux中的Middleware 记录日志 手动记录 redux-saga Generator函数 实际使用场景 引言 上一节我们学习了redux在实际项目的应用细节,这一节我们来学习redux中一个很重要的概念:中间件.我们会简单实现一个记录的中间件, 然后学习redux-saga这个异步请求中间件. redux中的Middleware redux中的中间件提供的是位于 action 被发起之后,到达 reducer 之前的扩展点. 你可以利用 Redux middleware

  • PHP分页函数代码(简单实用型)

    准备数据: 新建一个数据库 test 执行下面的语句(新建一个表 test :id.sex.name 三个字段) CREATE TABLE `test` ( `id` INT( 4 ) NOT NULL AUTO_INCREMENT PRIMARY KEY , `sex` INT( 1 ) NOT NULL , `name` VARCHAR( 20 ) NOT NULL ) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_bin; 添加数据到 te

  • PHP动态分页函数,PHP开发分页必备啦

    贴代码: 复制代码 代码如下: /** * 分页函数 * * @param int $count 条目总数 * @param int $perlogs 每页显示条数目 * @param int $page 当前页码 * @param string $url 页码的地址 */ function pagination($count,$perlogs,$page,$url,$anchor=''){ $pnums = @ceil($count / $perlogs); $re = ''; $urlHom

随机推荐