django有多条数据的时候 我们就需要使用分页 来加载数据
1 先导入我们需要的分页
from pure_pagination import Paginator,PageNotAnInteger
2 get请求方法 获取页数的参数 如果没有给一个默认值1
try:
page = request.GET.get('page', 1)
except PageNotAnInteger:
page = 1
3 然后查询数据库里的所有数据 ,加载分页
orgs = CourseOrg.objects.all()
my_orgs = Paginator(orgs,per_page=2, request=request)
orgs1 = my_orgs.page(page)
4 再把数据传回给前台模板
return render(request,'org-list.html',{'orgs':orgs1,})
5 前台页面再把数据渲染到网页里面
{% for org in orgs.object_list %}
<h1>{{ org.name }}</h1>
{% endfor %}
6 分页数加载
{% load i18n %}
<ul class="pagelist">
{% if orgs.has_previous %}
<li class="long"><a href="?{{ orgs.previous_page_number.querystring }}">上一页</a></li>
{% endif %}
{% for page in orgs.pages %}
{% if page %}
{% ifequal page orgs.number %}
<li class="active"><a href="?page=1">{{ page }}</a></li>
{% else %}
<li><a href="?{{ page.querystring }}" class="page">{{ page }}</a></li>
{% endifequal %}
{% else %}
...
{% endif %}
{% endfor %}
{% if orgs.has_next %}
<li class="long"><a href="?{{ orgs.next_page_number.querystring }}">下一页</a></li>
{% endif %}
</ul>