安装
pip install django-pure-pagination
注册应用
INSTALLED_APPS = (
'pure_pagination',
)
配置设置(settings.py)
PAGINATION_SETTINGS = {
'PAGE_RANGE_DISPLAYED': 1,
'MARGIN_PAGES_DISPLAYED': 2,
'SHOW_FIRST_PAGE_WHEN_INVALID': True,
}
编写试图
def index(request):
try:
page = request.GET.get('page',1)
except PageNotAnInteger:
page = 1
arts =Article.objects.all()
p = Paginator(arts,per_page = 1 ,request= request)
articles = p.page(page)
return render(request,'index.html',locals())
配置路由
from . import views
path('',views.index)
编写模板
<!DOCTYPE html>
{% load staticfiles %}
<html lang="en">
<head>
<meta charset="UTF-8">
<title>静态资源</title>
<link rel="stylesheet" href="{% static 'css/style.css'%}" type="text/css">
</head>
<body>
<ul>
{% for cat in cats.object_list %}
<li>{{ cat.name }}</li>
{% endfor %}
</ul>
{% include '_pagination.html' %}
#_pagination.html 是自己创建的文件,位置最好创建在templates#文件下,方便调用
</body>
</html>
_pagination.html
{% load i18n %}
<div class="pagination">
{% if cats.has_previous %}
<a href="?{{ cats.previous_page_number.querystring }}"
class="prev">上一页</a>
{% else %}
<span class="disabled prev">上一页 </span>
{% endif %}
{% for page in cats.pages %}
{% if page %}
{% ifequal page cats.number %}
<span class="current page">{{ page }}</span>
{% else %}
<a href="?{{ page.querystring }}" class="page">{{ page }}</a>
{% endifequal %}
{% else %}
...
{% endif %}
{% endfor %}
{% if cats.has_next %}
<a href="?{{ cats.next_page_number.querystring }}" class="next">下一页</a>
{% else %}
<span class="disabled next">下一页</span>
{% endif %}
</div>
效果如下