django--分页功能

Django 提供了强大的分页功能,可以轻松地在视图中实现分页。

在视图中使用分页:

复制代码
# views.py
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
from django.shortcuts import render
from .models import YourModel

def your_view(request):
    # 从数据库中获取所有数据
    all_data = YourModel.objects.all()

    # 设置每页显示的数据数量
    items_per_page = 10

    # 创建分页对象
    paginator = Paginator(all_data, items_per_page)

    # 获取当前请求的页码
    page = request.GET.get('page')

    try:
        # 获取指定页码的数据
        data = paginator.page(page)
    except PageNotAnInteger:
        # 如果页码不是整数,返回第一页的数据
        data = paginator.page(1)
    except EmptyPage:
        # 如果页码超出范围,返回最后一页的数据
        data = paginator.page(paginator.num_pages)

    # 渲染视图并传递分页数据
    return render(request, 'your_template.html', {'data': data})

在模板中显示分页:

复制代码
<!-- your_template.html -->
{% for item in data %}
    {# 显示数据 #}
    {{ item.field_name }}
{% endfor %}

{# 显示分页导航 #}
<div class="pagination">
    <span class="step-links">
        {% if data.has_previous %}
            <a href="?page=1"><< first</a>
            <a href="?page={{ data.previous_page_number }}">previous</a>
        {% endif %}

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

        {% if data.has_next %}
            <a href="?page={{ data.next_page_number }}">next</a>
            <a href="?page={{ data.paginator.num_pages }}">last >></a>
        {% endif %}
    </span>
</div>

这个模板中的分页导航演示了如何在模板中显示分页链接。它使用 data 对象中的信息,如 has_previous、previous_page_number、number、num_pages 等来生成分页导航链接。

相关推荐
ZWZhangYu4 小时前
LangChain 构建向量数据库和检索器
数据库·langchain·easyui
feifeigo1235 小时前
升级到MySQL 8.4,MySQL启动报错:io_setup() failed with EAGAIN
数据库·mysql·adb
火龙谷7 小时前
【nosql】有哪些非关系型数据库?
数据库·nosql
焱焱枫8 小时前
Oracle获取执行计划之10046 技术详解
数据库·oracle
qq_392397129 小时前
Redis常用操作
数据库·redis·wpf
小石潭记丶9 小时前
Django服务开发镜像构建
django·sqlite·pip
一只fish11 小时前
MySQL 8.0 OCP 1Z0-908 题目解析(17)
数据库·mysql
花好月圆春祺夏安11 小时前
基于odoo17的设计模式详解---装饰模式
数据库·python·设计模式
A__tao11 小时前
SQL 转 Java 实体类工具
java·数据库·sql
m0_6530313612 小时前
腾讯云认证考试报名 - TDSQL数据库交付运维专家(TCCE PostgreSQL版)
运维·数据库·腾讯云