
本文介绍一种纯逻辑公式驱动的方法,使用单个 for 循环,在给定总页数($pager_max)和当前索引($current)的前提下,精确输出包含「前一项、当前项、后两项」共最多 4 个数字的序列,并自动处理首尾边界(如当前为 1 或末尾时自动收缩范围),全程不依赖内置函数如 range() 或 array_slice()。
要实现题目中描述的分页导航逻辑——即对任意 $current(1 ≤ $current ≤ $pager_max),始终显示最多 4 个连续数字,其中当前项居中偏右(结构为:[prev] [current] [next1] [next2]),并在边界处智能截断(如 $current = 1 时只能显示 1 2 3 4;$current = 8 且 $pager_max = 8 时显示 5 6 7 8),关键在于用纯算术公式动态确定循环的起始与结束位置,而非依赖数组函数。
核心思路是:固定输出项数为 4,但根据 $current 的位置决定窗口左边界 start 和右边界 end,使其满足:
- 包含 $current;
- 尽可能包含 $current - 1、$current + 1、$current + 2;
- 所有值必须 ∈ [1, $pager_max]。
因此,我们可推导出:
- 理论左边界:$current - 1(要包含前一项)
- 理论右边界:$current + 2(要包含后两项)
-
实际左边界:max(1, min($current - 1, $pager_max - 3))
→ 解释:既要 ≥1,又要保证右侧有足够空间(若 $current - 1 太大,会导致 $current + 2 > $pager_max,此时需左移整个窗口,使右边界恰好为 $pager_max,故左边界至少为 $pager_max - 3) -
实际右边界:min($pager_max, max($current + 2, 4))
→ 更简洁做法是:先确定左边界 start,再令 end = min($pager_max, $start + 3)(因最多 4 个数)
但题目明确要求仅用一个 for 循环 + 公式判断(不写函数、不调用 range),因此我们直接在循环中用条件筛选应显示的 $i:
立即学习“PHP免费学习笔记(深入)”;
Easily find JSON paths within JSON objects using our intuitive Json Path Finder
= $pager_max - 1) ? $pager_max - 3 : $current - 1;
$end = min($pager_max, $start + 3);
for ($i = 1; $i <= $pager_max; $i++) {
if ($i >= $start && $i <= $end) {
echo $i . '
';
}
}
?>✅ 验证示例:
- $current = 1 → $start = 1, $end = min(8, 4) = 4 → 输出 1 2 3 4
- $current = 8, $pager_max = 8 → $current >= 8-1 → $start = 8-3 = 5, $end = min(8, 5+3)=8 → 输出 5 6 7 8
- $current = 4 → $start = 4-1 = 3, $end = 6 → 输出 3 4 5 6
⚠️ 注意事项:
- 公式中 $pager_max - 3 是关键:确保当 $current 靠近末尾时,窗口仍能容纳 4 个数(即 [$pager_max-3, $pager_max] 长度为 4);
- 不可直接用 $i $current - 2,因为未约束整体区间上限,会导致 $current = 1 时出现 0 或负数;
- 本解法完全符合“仅用 for 循环 + 算术公式”要求,无函数调用、无数组构造,逻辑清晰且易于嵌入模板。
总结:边界处理的本质是以当前项为锚点,向左争取 1 位、向右争取 2 位,再用 max(1, ...) 和 min($pager_max, ...) 双重钳制。掌握这一模式,即可轻松适配任意 $pager_max,实现鲁棒的分页数字导航。










