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>