PHP数组分页可通过array_slice切片实现,封装为函数增强复用性,结合HTML生成导航链接,大数据量时用SplFixedArray优化性能,关联数组需自定义切片保留键名。

如果您需要在PHP中对数组数据进行分页展示,但不使用数据库查询,而是直接对已存在的数组进行切片处理,则可以通过计算偏移量和限制数量来实现分页效果。以下是实现此功能的多种方法:
一、使用array_slice函数实现分页
该方法利用PHP内置的array_slice函数,根据当前页码和每页条数,从原始数组中截取对应范围的数据。它简洁高效,适用于中小型数组,且无需修改原数组结构。
1、定义原始数组,例如 $data = [1, 2, 3, ..., 100];
2、设定每页显示数量 $per_page = 10;
立即学习“PHP免费学习笔记(深入)”;
3、获取当前页码 $page = isset($_GET['page']) ? (int)$_GET['page'] : 1;
4、确保页码不小于1,$page = max(1, $page);
5、计算起始偏移量 $offset = ($page - 1) * $per_page;
6、调用 array_slice($data, $offset, $per_page) 获取当前页数据;
7、使用 count($data) 计算总条数,进而推导总页数 $total_pages = ceil(count($data) / $per_page);
二、封装为可复用的分页函数
将分页逻辑抽象为独立函数,增强代码复用性与可维护性。该函数接收数组、页码、每页数量三个参数,返回包含分页数据与元信息的关联数组。
1、声明函数 function paginate_array($array, $page = 1, $per_page = 10) {;
2、在函数内校验输入:if (!is_array($array) || $per_page [], 'total' => 0, 'page' => 1, 'per_page' => $per_page, 'pages' => 0];
3、计算总条数 $total = count($array);
4、计算总页数 $pages = (int)ceil($total / $per_page);
5、修正页码上限:$page = min($page, $pages);
6、计算偏移量 $offset = ($page - 1) * $per_page;
7、截取数据 $data = array_slice($array, $offset, $per_page);
8、返回包含 data、total、page、per_page、pages 键的数组;
三、结合HTML生成分页导航链接
在输出分页数据的同时,需提供前端可点击的页码导航。该方法通过拼接当前URL参数(保留原有查询字符串),动态生成带 page 参数的链接,避免丢失其他请求变量。
标签: mysql php html 前端 大数据 ai 代码复用 键值对
还木有评论哦,快来抢沙发吧~