Django视图中的分页处理

2023-04-11 00:00:00 django 视图 分页

在Django视图中进行分页处理,可以使用Django自带的Paginator类。Paginator类的实例需要传入两个参数:一个查询集和每页显示的记录数。然后,可以通过实例的page方法获取指定页数的记录对象。

例如,假设我们有一个名为Article的模型,我们要在视图中显示所有文章,每页显示10条记录。可以按如下方式分页处理:

from django.core.paginator import Paginator
from django.shortcuts import render
from .models import Article

def article_list(request):
    articles = Article.objects.all()
    paginator = Paginator(articles, 10)
    page_number = request.GET.get('page')
    page_obj = paginator.get_page(page_number)
    return render(request, 'article_list.html', {'page_obj': page_obj})

上述代码中,首先获取所有文章记录,然后创建Paginator实例,将查询集和每页显示的记录数传入。接着,通过request.GET对象获取当前页数,并调用Paginator实例的get_page方法获取指定页数的记录对象。最后,将记录对象传递给模板渲染,并在模板中使用内置模板标签进行分页展示。

模板代码示例:

{% for article in page_obj %}
    <h2>{{ article.title }}</h2>
    <p>{{ article.content }}</p>
{% endfor %}

<div class="pagination">
    <span class="step-links">
        {% if page_obj.has_previous %}
            <a href="?page=1">&laquo; first</a>
            <a href="?page={{ page_obj.previous_page_number }}">&lsaquo; prev</a>
        {% endif %}

        <span class="current-page">
            Page {{ page_obj.number }} of {{ page_obj.paginator.num_pages }}.
        </span>

        {% if page_obj.has_next %}
            <a href="?page={{ page_obj.next_page_number }}">next &rsaquo;</a>
            <a href="?page={{ page_obj.paginator.num_pages }}">last &raquo;</a>
        {% endif %}
    </span>
</div>

上述模板代码中,利用Paginator类中的num_pages属性获取分页总数,然后使用内置模板标签判断是否有前一页和后一页,生成相应的分页链接。如果需要显示当前页数,可以通过Paginator实例的number属性获取。

相关文章