栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP

PHP封装分页函数实现文本分页和数字分页

PHP 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

PHP封装分页函数实现文本分页和数字分页

最近,在项目中要用到分页。分页功能是经常使用的一个功能,所以,对其以函数形式进行了封装。

// 分页分装

function paging($pageType)
{
global $pageTotal,$page,$total;
if($pageType == 1)
{
echo '';
echo'
    ';
    for($i=0; $i < $pageTotal; $i++)
    {
    if($page == ($i+1))
    {
    echo '
  • '.($i+1).'
  • ';
    }
    else
    {
    echo '
  • '.($i+1).'
  • ';
    }
    }
    echo'
';
echo'';

}
else if($pageType == 2)
{
echo '';
echo '
    ';
    echo '
  • '.$page.'/'.$pageTotal.'页 |
  • ';
    echo '
  • 共有'.$total .'个会员 |
  • ';
    // 第一页
    if($page == 1)
    {
    echo '
  • 首页 |
  • ';
    echo '
  • 上一页 |
  • ';
    }
    else
    {
    // $_SERVER["script_NAME"]获取当前的脚本名字,方便移植
    // 也可以自定义常量,常量值和脚本文件名一致
    echo '
  • 首页 |
  • ';
    echo '
  • 上一页 |
  • ';
    }
    // 最后一页
    if($page == $pageTotal)
    {
    echo '
  • 下一页 |
  • ';
    echo '
  • 尾页 |
  • ';
    }
    else
    {
    echo '
  • 下一页 |
  • ';
    echo '
  • 尾页 |
  • ';
    }
    echo '
';
echo '';
}
}

参数解释:

$pageTotal是总页数,$page是当前页,$total是从数据库中获取的数据总数;

为了简化,将参数全部封装

// 分页参数分装

function pageParam($sql,$size)
{
// 将所有涉及的参数设置全局变量
// $pagestart 某一页从哪里开始
// $total 总记录数 $page 某一页 $pageTotal 总页数
global $pagestart,$pagesize,$total,$page,$pageTotal;
$pagesize = $size;
// 获取数据总数
$total = mysql_num_rows(queryDB($sql));

// 错误处理,先判断是否存在
if(isset($_GET['page']))
{
// 具体某一页
$page = $_GET['page'];
// 判断是否为空(0是空)/小于0/是否是数字
if(empty($page) || $page < 0 || !is_numeric($page))
{
$page = 1;
}
else
{
$page = intval($page); //取整,防止小数出现
}

}
else
{
// 初始化显示第1页
$page = 1;
}

// 数据库清零
if($total == 0)
{
// 设置为1
$pageTotal = 1;
}
else
{
// 分页的总页数(进一取整处理)
$pageTotal = ceil($total / $pagesize);
}

// 页数大于总页码$total
if($page > $pageTotal)
{
$page = $pageTotal;
}
// 当页从某一条记录开始
$pagestart = ($page - 1) * $pagesize;
}

参数解释:

$pagestart是当页从某一条记录开始,$pagesize是每页显示的记录数

在使用中,先调用pageParam,再调用paging


pageParam("select userid from user",2);
  // 分页类型 1是数字分页 2是文本分页
paging(2);
?>

调用的位置根据具体情况选择,文本分页如下:

    // 分页类型 1是数字分页 2是文本分页
paging(1);
?>

数字分页如下:

样式自行调整。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/47213.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号