Пагинация в трясогузке с циклом {% для%} - PullRequest
0 голосов
/ 06 апреля 2020

У меня есть некоторые проблемы с пониманием django разбиение на страницы в Wagtail cms. Я прочитал эту топи c Пагинация в трясогузке

Так что это не работает для меня хорошо. В моих шаблонах для получения продуктов я использую этот код

                {% for product in page.get_children.specific %}
                <div class="col-12 col-sm-6 col-lg-4">
                    <div class="single-best-receipe-area mb-30">
                        {% image product.product_photo width-400 %}
                        <div class="receipe-content">
                            <a href="{% pageurl product %}">
                                <h5>{{ product.title }}</h5>
                            </a>
                        </div>
                    </div>
                </div>
                {% endfor %}

, а затем:

    <ul class="pagination">
        {% if product.has_previous %}
        <li><a href="?page={{ product.previous_page_number }}"><i class="fa fa-angle-left"></i></a></li>
        {% endif %}
        {% for page_num in product.paginator.page_range %}
        <li {% if page_num == product.number %}class="active" {% endif %}><a
                href="?page={{ page_num }}">{{ page_num }}</a></li>
        {% endfor %}
        {% if product.has_next %}
        <li><a href="?page={{ product.next_page_number }}"><i class="fa fa-angle-right"></i></a></li>
        {% endif %}
    </ul>

в моих models.py я использую это:

class ProductsPage(Page):
body = models.CharField(max_length=255, blank=True, help_text = 'Описание страницы')
product_image = models.ForeignKey(
    "wagtailimages.Image", 
    null=True,
    blank=True,
    on_delete=models.SET_NULL,
    related_name='+',
    help_text='Фотография Категории'
    )
content_panels = Page.content_panels + [
    FieldPanel('body', classname="full"),
    ImageChooserPanel('product_image'),
]
def get_context(self, request):
    context = super(ProductsPage, self).get_context(request)
    all_product = OneProduct.objects.live()
    paginator = Paginator(all_product, 1) # Show 3 product per page
    page = request.GET.get('page')
    try:
        product = paginator.page(page)
    except PageNotAnInteger:
    # If page is not an integer, deliver first page.
        product = paginator.page(1)
    except EmptyPage:
    # If page is out of range (e.g. 9999), deliver last page of results.
        product = paginator.page(paginator.num_pages)

# make the variable 'product' available on the template
    context['product'] = product

    return context

окончательно Я видел нумерацию страниц, но на каждой странице есть все продукты, и я понимаю, что проблема в этой части шаблона

{% for product in page.get_children.specific %}

, потому что я беру все продукты. Но как я могу решить эту проблему?

1 Ответ

0 голосов
/ 10 апреля 2020

Я не уверен, что ваша переменная контекста будет правильной в вашем шаблоне. Вы можете попробовать получить все продукты all_products = OneProduct.objects.all()

Не лучший, но рабочий пример нумерации страниц. Это может вам помочь.

paginator = Paginator(data, amount) # amount of products per page
page_number = request.GET.get('page', 1)
page = paginator.page(page_number)
is_paginated = page.has_other_pages()

if page.has_previous():
    prev_url = '?page={}'.format(page.previous_page_number())
else:
    prev_url = ''

if page.has_next():
    next_url = '?page={}'.format(page.next_page_number())
else:
    next_url = ''

last_url = '?page={}'.format(page.paginator.page_range[-1])

И передать page в вашу переменную контекста context ={'page_object': page}.

Так что вы можете использовать это для цикла {% for product in page_object.object_list %}

...