Django分页的基本实现办法
2016-03-13 11:45
393 查看
Django自带一个分页模块Pagination,具体的参考官方文档,我在这里简单介绍一下具体的例子,模拟一个常用场景,列出部分的代码出来。场景是这样的:我们有一个blog表,其中有若干条记录,我们要对这些记录集进行分页,每页有10条记录,把页码列举出来,页码以a标签的方式链接到本身页码的页面(注意:不是采用Ajax的方式)。
第一步,取出blog表的全部记录,定义每页记录数,定义当前页 前边页码范围和后边页码范围。
views.py
....
from django.core.paginator import Paginator,InvalidPage,EmptyPage,PageNotAnInteger
blogs=Blog.objects.all()
page_size=10
after_range_num = 5
before_range_num = 6
try:
page = int(request.GET.get("page",1))
if page < 1:
page = 1
except ValueError:
page = 1
paginator = Paginator(blogs,page_size)
try:
blogs = paginator.page(page)
except(EmptyPage,InvalidPage,PageNotAnInteger):
blogs = paginator.page(1)
if page >= after_range_num:
page_range = paginator.page_range[page-after_range_num:page+before_range_num]
else:
page_range = paginator.page_range[0:int(page)+before_range_num]
template_var["page_objects"]=blogs
template_var["page_range"]=page_range
....
第二步,在template页面上显示一页数据
index.html
....
{% for b in page_objects.object_list%}
<div class="node_article">
<h3><a href='{{b.get_absolute_url}}'>{{b.title}}</a></h3>
<p>{{b.content|safe|escape}}</p>
</div>
{%endfor%}
....
page_objects对象不能看做blog的记录集,page_objects.object_list才是你想要的,然后循环输出记录,把该页的数据集呈现出来。
第三部,页码呈现。
index.html
....
<p class="page_container">
{% if page_objects.has_previous %}
<a href="?page={{ page_objects.previous_page_number }}" title="Pre">上一页</a> {% endif %}
{% for p in page_range %}
{% ifequal p page_objects.number %}
<span style="font-size:16px;" title="当前页"><b>{{p}}</b></span>
{% else %}<a href="?page={{p}}" title="第{{p}}页">{{p}}</a>{% endifequal %}
{% endfor %}
{% if page_objects.has_next %}
<a href="?page={{ page_objects.next_page_number }}" title="Next">下一页</a>
{% endif %}
<b>
{%if page_objects.paginator.num_pages%}共 {{ page_objects.paginator.num_pages }} 页{%endif%}
</b>
</p>
....
第一步,取出blog表的全部记录,定义每页记录数,定义当前页 前边页码范围和后边页码范围。
views.py
....
from django.core.paginator import Paginator,InvalidPage,EmptyPage,PageNotAnInteger
blogs=Blog.objects.all()
page_size=10
after_range_num = 5
before_range_num = 6
try:
page = int(request.GET.get("page",1))
if page < 1:
page = 1
except ValueError:
page = 1
paginator = Paginator(blogs,page_size)
try:
blogs = paginator.page(page)
except(EmptyPage,InvalidPage,PageNotAnInteger):
blogs = paginator.page(1)
if page >= after_range_num:
page_range = paginator.page_range[page-after_range_num:page+before_range_num]
else:
page_range = paginator.page_range[0:int(page)+before_range_num]
template_var["page_objects"]=blogs
template_var["page_range"]=page_range
....
第二步,在template页面上显示一页数据
index.html
....
{% for b in page_objects.object_list%}
<div class="node_article">
<h3><a href='{{b.get_absolute_url}}'>{{b.title}}</a></h3>
<p>{{b.content|safe|escape}}</p>
</div>
{%endfor%}
....
page_objects对象不能看做blog的记录集,page_objects.object_list才是你想要的,然后循环输出记录,把该页的数据集呈现出来。
第三部,页码呈现。
index.html
....
<p class="page_container">
{% if page_objects.has_previous %}
<a href="?page={{ page_objects.previous_page_number }}" title="Pre">上一页</a> {% endif %}
{% for p in page_range %}
{% ifequal p page_objects.number %}
<span style="font-size:16px;" title="当前页"><b>{{p}}</b></span>
{% else %}<a href="?page={{p}}" title="第{{p}}页">{{p}}</a>{% endifequal %}
{% endfor %}
{% if page_objects.has_next %}
<a href="?page={{ page_objects.next_page_number }}" title="Next">下一页</a>
{% endif %}
<b>
{%if page_objects.paginator.num_pages%}共 {{ page_objects.paginator.num_pages }} 页{%endif%}
</b>
</p>
....
相关文章推荐
- Django实战(20):分页(Pagination)
- Django 开发Tutorial part_1
- RESTful之Content negotiation
- GO1.6语言学习笔记1-基础篇
- Mongo Bson数据
- Machine Learning - Neural Networks Representation Part II
- Go语言黑魔法中的问题修正
- 编写GO的WEB开发框架 (十一): status页面和实时统计
- Django – vicalloy's trac
- django-extensions 文档 — django-extensions 1.2.5 文档
- Machine Learning - Neural Networks Representation Part I
- AlphaGo 3:0 胜李世石九段 100年后
- Django入门笔记
- AlphaGo来了,终结者不远了
- [HDOJ] 5546 Ancient Go [DFS]
- Django学习笔记(五)—— 表单
- 李世石三比零败于AlphaGo,AlphaGo获胜已无悬念
- 蓝桥杯 ALGO-108 最大体积 (动态规划)
- hdu 5546 Ancient Go(★)
- 读书笔记:Mastering the game of Go with deep neural networks and tree search