Django pagination ... нарезать страницы, чтобы показать долю от общего количества страниц? - PullRequest
15 голосов
/ 25 марта 2011

У меня модуль разбивки на страницы работает по большей части, но есть одна проблема. Как я могу показать только часть всех доступных страниц. Например, допустим, я на странице 5 из n страниц, я хотел бы показать.

1,2,3,4,5,6 .... (п-1) (п).

Я полагаю, что у Руби есть какая-то необычная внешняя магия для достижения этой цели. Что я могу сделать в модуле django?

При просмотре других сайтов кажется, что логика в основном идет, выбирайте фиксированное количество мест. Если это число больше отображаемой в данный момент суммы, добавьте элементы при переходе на страницу пользователя. По достижении этого количества точек показывайте только x точек слева и справа от текущей страницы.

Должен ли я просто написать собственную логику шаблона для достижения этой цели?

Спасибо

Ответы [ 4 ]

11 голосов
/ 25 марта 2011

Несколько хороших статей о реализации того, что вы просите в django. Множество сменных пакетов для настройки, если вы не хотите делать свои собственные.

http://www.tummy.com/Community/Articles/django-pagination/

https://github.com/dcramer/django-paging

Очень хороший фрагмент документа, который охватывает встроенный paginator:

http://blog.elsdoerfer.name/2008/03/06/yet-another-paginator-digg-style/

7 голосов
/ 25 марта 2011

Я только что реализовал это, используя "Digg-like Paginator" от Django Snippets .

Это определенно то, что вы ищете.

Просто выведите этот кодв модуль Python, например digg_paginator.py, и импортируйте его следующим образом ...

from django.core.paginator import InvalidPage, EmptyPage #, Paginator
from digg_paginator import DiggPaginator as Paginator

Затем в моих шаблонах мне пришлось переключиться с ...

{% for page_num in page.paginator.page_range %}

на

{% for page_num in page.page_range %}

Вот и все!DiggPaginator имеет точно такой же интерфейс, как встроенный в Django плюс некоторые функции, так что вы можете просто установить его на место и затем настроить его с некоторыми настройками, если вы чувствуете необходимость.

2 голосов
/ 25 марта 2011

Мне недавно пришлось сделать то же самое для моего сайта Wantbox.com и я нашел очень простое и эффективное решение.

Я добавляю этот фрагмент в каталог «templatetags» моего приложения в файле с именем «paginator.py»:

#  Based on: http://www.djangosnippets.org/snippets/73/
#
#  Modified by Sean Reifschneider to be smarter about surrounding page
#  link context.  For usage documentation see:
#
#     http://www.tummy.com/Community/Articles/django-pagination/

from django import template

register = template.Library()

def paginator(context, adjacent_pages=2):
    """
    To be used in conjunction with the object_list generic view.

    Adds pagination context variables for use in displaying first, adjacent and
    last page links in addition to those created by the object_list generic
    view.

    """
    startPage = max(context['page'] - adjacent_pages, 1)
    if startPage <= 3: startPage = 1
    endPage = context['page'] + adjacent_pages + 1
    if endPage >= context['pages'] - 1: endPage = context['pages'] + 1
    page_numbers = [n for n in range(startPage, endPage) \
            if n > 0 and n <= context['pages']]
    page_obj = context['page_obj']
    paginator = context['paginator']

    return {
        'page_obj': page_obj,
        'paginator': paginator,
        'hits': context['hits'],
        'results_per_page': context['results_per_page'],
        'page': context['page'],
        'pages': context['pages'],
        'page_numbers': page_numbers,
        'next': context['next'],
        'previous': context['previous'],
        'has_next': context['has_next'],
        'has_previous': context['has_previous'],
        'show_first': 1 not in page_numbers,
        'show_last': context['pages'] not in page_numbers,
    }

register.inclusion_tag('paginator.html', takes_context=True)(paginator)

Затем я добавляю это на страницу, где я хочу нумерацию страниц:

<div>{% if is_paginated %}{% load paginator %}{% paginator 3 %}{% endif %}</div>

Изменение «3» на «2» или «4» изменяет усечение нумерации страниц. Вы можете увидеть пример на моем сайте здесь (вверху справа на странице).

0 голосов
/ 27 сентября 2017

Если вы используете ListView, вот ваша функция разбиения на страницы:

def paginator(context, adjacent_pages=2):
    """
    To be used in conjunction with the object_list generic view.

    Adds pagination context variables for use in displaying first, adjacent and
    last page links in addition to those created by the object_list generic
    view.

    """
    startPage = max(context['page_obj'].number - adjacent_pages, 1)
    if startPage <= 3: startPage = 1
    endPage = context['page_obj'].number + adjacent_pages + 1
    if endPage >= context['paginator'].num_pages - 1: endPage = context['paginator'].num_pages + 1
    page_numbers = [n for n in range(startPage, endPage) \
            if n > 0 and n <= context['paginator'].num_pages]
    page_obj = context['page_obj']
    paginator = context['paginator']

    return {
        'page_obj': page_obj,
        'paginator': paginator,
        'page': context['page_obj'].number,
        'pages': context['paginator'].num_pages,
        'page_numbers': page_numbers,
        'next': context['page_obj'].next_page_number,
        'previous': context['page_obj'].previous_page_number,
        'has_next': context['page_obj'].has_next,
        'has_previous': context['page_obj'].has_previous,
        'show_first': 1 not in page_numbers,
        'show_last': context['paginator'].num_pages not in page_numbers,
    }

Мой шаблон

    <nav>
        <ul class="pagination">
            <li{% if not page_obj.has_previous %} class="disabled"{% endif %}>
                <a {% if page_obj.has_previous %} href="?{{ path }}page={{ page_obj.previous_page_number }}"{% endif %}><i
                        class="fa fa-angle-left"></i></a>
            </li>
            {% if show_first %}
                <li><a href="?{{ path }}page=1">1</a></li>
                <li class="disabled"><a>&hellip;</a></li>
            {% endif %}
            {% for linkpage in page_numbers %}
                {% ifequal linkpage page %}
                    <li class="active"><a>{{ page }}</a></li>
                {% else %}
                    <li><a href="?{{ path }}page={{ linkpage }}">{{ linkpage }}</a></li>
                {% endifequal %}
            {% endfor %}
            {% if show_last %}
                <li class="disabled"><a>&hellip;</a></li>
                <li><a href="?{{ path }}page=last">{{ pages }}</a></li>
            {% endif %}
            <li{% if not page_obj.has_next %} class="disabled"{% endif %}>
                <a {% if page_obj.has_next %}  href="?{{ path }}page={{ page_obj.next_page_number }}"{% endif %}><i
                        class="fa fa-angle-right"></i></a>
            </li>
        </ul>
</nav>
...