php 分页 - 如何限制显示的页面数

标签 php pagination

我很难理解如何限制分页的页数。我正在尝试在数据库中列出我的文章,但我有超过 500 页!我只想一次最多显示大约 15 个页码。我似乎无法理解其他问题中给出的答案。

这是我的分页代码:

<?php 
    require 'core/init.php';

    $page = isset($_GET['page']) ? (int)$_GET['page'] : 1;
    if(!isset($_GET['page'])){
        $_GET['page'] = 1;
    }
    if(! (int)$_GET['page']){
        $_GET['page'] = 1;
    }
    if($_GET['page'] < 1){
        $_GET['page'] = 1;
    }
    $perPage = 18;
    $start = ($page > 1) ? ($page * $perPage) - $perPage : 0; 

    $articles = DB::getInstance()->query("SELECT SQL_CALC_FOUND_ROWS * FROM articles ORDER BY added DESC LIMIT {$start}, {$perPage}");

    foreach($articles->results() as $article){ ?>
        <div class="article-container">
            <h2><?php echo $article->title; ?></h2>
        </div>
    <?php 
    }

    // pagination 

    $total = DB::getInstance()->query("SELECT FOUND_ROWS() as total");

    $total = $total->results()[0];

    foreach ($total as $total => $value) {

    }

    $pages = ceil($value / $perPage);
    $maxpage = 15;
?>
<div class="pagination"> 
    <?php if($_GET['page'] >= 2){
        echo '<a href="?page=' . ($_GET['page'] -1) . '" class="paginationButton">Prev</a>';
    }
    for ($i=1; $i <= $pages; $i++) : ?>
        <a href="?page=<?php echo $i; ?>" <?php if($page === $i) { echo 'class="pageSelected"'; } ?>><?php echo $i; ?></a>
    <?php   endfor;
        if((int)$_GET['page'] != $i - 1 ){
            echo '<a href="?page=' . ($_GET['page'] +1) . '"class="paginationButton">Next</a>';
        }
    ?>
</div>

这按预期工作,但它只显示从 1 到 500 的页数。显示类似内容的最佳/最简单方法是什么:

1 2 3 4 5 6 7 8 9 10 11 12 13 ... >

最佳答案

你需要改变你的for循环,起点和终点

$count = 9;
$startPage = max(1, $page - $count);
$endPage = min( $pages, $page + $count);
for($i = $startPage; $i < $endPage; $i++) {
    // write out the link to the page
}

那么如果页面是 250,它将仅显示 241, 242, ..., 250, ..., 257, 258

关于php 分页 - 如何限制显示的页面数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37190513/

相关文章:

php - 返回为 dompdf 分页分组的每个 "user"的结果

php - empty() 够用还是用 isset()?

php - Codeigniter mysql 查询使用 UNION 首先选择等于今天日期的值

php - 在 Codeigniter 中将 If Else 与 Foreach 一起使用

php - 如何在分页结果时让查询转移到后续页面

c# - WPF 数据网格分页

pagination - 如何通过引用 Android Auto MediaBrowser 在 MediaBrowserServiceCompat 中设置 EXTRA_PAGE 和 EXTRA_PAGE_SIZE?

php - 如何在匿名函数中从数组中获取键?

javascript - 使用 ng-repeat 在列表上分页

grails - Grails中的分页概率