SilverStripe PaginatedPages显示自定义摘要

时间:2017-05-01 17:46:04

标签: php pagination silverstripe

我在使用PaginatedPages时遇到了麻烦。在docs中,可以自定义摘要。

有我的代码:

public function PaginatedPages($n = 10) {
    $list = Page::get()->sort(array('Date' => DESC));
    $Pages = new PaginatedList($list, $this->request);
    if ($_GET['results'] != "") {
        $n = $_GET['results'];
    }
    $Pages->setPageLength($n);
    return $Pages;
}

模板页面底部的分页:

<div id="PaginatedPages">
    <% if $PaginatedPages.MoreThanOnePage %>
        <% if $PaginatedPages.NotFirstPage %>
            <a class="prev" href="$PaginatedPages.PrevLink"><</a>
        <% end_if %>
        <% loop $PaginatedPages.Pages %>
            <% if $CurrentBool %>
                <a class="current">$PageNum</a>
            <% else %>
                <% if $Link %>
                    <a href="$Link">$PageNum</a>
                <% else %>
                    ...
                <% end_if %>
            <% end_if %>
            <% end_loop %>
        <% if $PaginatedPages.NotLastPage %>
            <a class="next" href="$PaginatedPages.NextLink">></a>
        <% end_if %>
    <% end_if %>
</div>

此代码重现:

[1][2][3][4][5][6][7][8][9][10][11][12][13][14][15][16][17][18][19][20]

我不想要这个。如果有20页的结果,它将显示所有结果,结果是长而丑。

我想要以下内容:

[1] ... [9] [10] [11] [12] [13] ... [20]

1 个答案:

答案 0 :(得分:6)

您可以使用$PaginatedPages.PaginationSummary来实现此目标:

<div id="PaginatedPages">
    <% if $PaginatedPages.MoreThanOnePage %>
        <% if $PaginatedPages.NotFirstPage %>
            <a class="prev" href="$PaginatedPages.PrevLink"><</a>
        <% end_if %>
        <% loop $PaginatedPages.PaginationSummary %>
            <% if $CurrentBool %>
                <a class="current">$PageNum</a>
            <% else %>
                <% if $Link %>
                    <a href="$Link">$PageNum</a>
                <% else %>
                    ...
                <% end_if %>
            <% end_if %>
            <% end_loop %>
        <% if $PaginatedPages.NotLastPage %>
            <a class="next" href="$PaginatedPages.NextLink">></a>
        <% end_if %>
    <% end_if %>
</div>

PaginationSummary返回一个摘要分页,该分页限制了当前页面周围显示的页面数,以实现视觉平衡。它

PaginationSummary可以使用参数来控制当前页面周围显示的页数。默认情况下,PaginationSummary将在当前页面周围显示4个页面(之前2页,之后2页。例如[1] ... [4] [5] [[6]] [7] [8] ... [25])。调用PaginationSummary(6)将导致当前页面之前3页和当前页面之后3页。例如[1] ... [3] [4] [5] [[6]] [7] [8] [9] ... [25]。数字应该始终是均匀的,因为每页的数量的一半显示在当前页面的两侧。