设为首页 加入收藏

TOP

php分页数据最后一页继续追加第一页数据
2019-08-23 00:42:18 】 浏览:28
Tags:php 数据 最后 继续 追加 第一

之前做数据分页遇到这样一个需求,就是数据到最后一页的时候不能中断,继续把第一页的数据追加到后面,无限显示下去。
原文地址:代码汇个人博客 http://www.codehui.net/info/23.html

一般情况我们写数据分页都是如下代码

//分页码
$page = $_REQUEST['page'];
//显示条数
$limit = 10;
//分页开始条数
$start_limit = ($page - 1) * $limit;
//运行sql语句得到的结果
$list = model('table')->limit("$start_limit, $limit")->findAll();
//返回数据
return $list;

比如我们有102条数据,到了11页的时候就会只有2条数据,显然这不是我们要的结果。如果我们想要第11页数据显示的是最后的2条+第1页的前8条,就不能用这种方法了。

//分页码
$page  = $_REQUEST['page']; 
//显示条数
$limit = 10;
//数据总条数
$count = model('table')->count();
//取模
$pattern = (($page - 1) * $limit) % $count;  
//余条数
$pattern_limit = $pattern % $limit;
//获取数据
$list = model('table')->limit("$pattern, $limit")->findAll();
//数据条数小于页面显示条数 继续查询进行追加
if(count($list) < $limit){
    //差数据条数
    $remainder = $limit - count($list);
    //重头开始查询数据
    $new_list = model('table')->limit("0, $remainder")->findAll();
    //合并数据
    $list      = array_merge($list, $new_list);
}
return $list;
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇windows下基于IIS配置ssl证书 下一篇emlog 百度熊掌号提交插件-基于Em..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目