Django中分页器的使用

1.子应用中的view.py

from paginator_app.models import Student
from django.shortcuts import render
from .models import Student
# Create your views here.
from django.core.paginator import Paginator,Page
from django.conf import settings
def student_list(request,num=1):
    num = request.GET.get('num')
    # 获取学生数据 (所有)
    student_list = Student.objects.all()
    # 创建分页器对象
    paginator = Paginator(student_list,per_page=settings.PER_SIZE)
    # 获取 某一页的数据
    page_list = paginator.get_page(num)    # 返回的是Page类
    # 定义分页栏的第一位
    start = int(num) -int(5/2)
    # 定义分页栏的最后一位
    end = start + 5
    # num_pages  指的是总页数
    if end > page_list.paginator.num_pages:
        end = page_list.paginator.num_pages
    if start <1:
        start = 1
    per_list = []
    for i in range(start,end+1):
        per_list.append(i)

    return render(request,'student.html',{'page_list':page_list,'per_list':per_list})
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <table>
        <tr>
            <th>序号</th>
            <th>姓名</th>
            <th>年龄</th>
            <th>性别</th>
            <th>身份证</th>
        </tr>
        {% for student in page_list.object_list %}
            <tr>
                <!-- {{forloop.counter}} 序号从1开始 -->
                <th>{{page_list.start_index|add:forloop.counter0}}</th>
                <th>{{student.name}}</th>
                <th>{{student.age}}</th>
                <th>{{student.sex}}</th>
                <th>{{student.card_no}}</th>
            </tr>
        {% endfor %}<!--  -->
    </table>
    <nav>
        <tr>
            <th>
                <a href="?num=1">首页</a>
            </th>
            <th>
                <!-- has_previous 上一页是否存在 -->
                {% if page_list.has_previous %}
                <!-- previous_page_number 是上一页的页码 -->
                <a href="?num={{page_list.previous_page_number}}">上一页</a>
                {% endif %}
            </th>   
            <th>
                {% for p in per_list %}
                <a href="?num={{p}}">{{p}}</a>
                {% endfor %}
            </th>
            <th>
                <!--has_next 下一页是否存在  -->
                {% if page_list.has_next %}
                <!-- next_page_number 下一页页码 -->
                <a href="?num={{page_list.next_page_number}}">下一页</a>
                {% endif %}
            </th>
            <th>
                <!-- num_pages 总页数 -->
                <a href="?num={{page_list.paginator.num_pages}}">末页</a>
                <a href="">总共{{page_list.paginator.num_pages}}页</a>
                <!-- number 当前页数 -->
                <a href="">当前{{page_list.number}}页</a>
            </th>
        </tr>
    </nav>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宠乖仪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值