轻松搞定Django分页功能
view代码
from django.core.paginator import Paginator
def announcement(request):
ctx = {
'global': GlobalCtx,
'announcements': models.Announcement.objects.all(),
}
paginator = Paginator(ctx['announcements'], Config.admin.paginator_limit) # Config.admin.paginator_limit 每一页显示数量
ctx['paginator'] = paginator.page(request.GET.get('page', '1'))
return render(request, 'announcement.html', ctx)
网页代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" crossorigin="anonymous">
</head>
<body class="container">
<table class="table table-striped table-bordered table-hover table-condensed">
<thead>
<tr class="danger">
<th>时间</th>
<th>发布者</th>
<th>标题</th>
<th>内容</th>
</tr>
</thead>
<tbody>
{% if paginator %}
{% for a in paginator %}
<tr class="{% cycle 'active' 'success' 'warning' 'info' %}">
<td>{{ a.publish|date:'Y-m-d H:i:s' }}</td>
<td>{{ a.username }}</td>
<td>{{ a.title }}</td>
<td>{{ a.content }}</td>
</tr>
{% endfor %}
{% else %}
<tr>
<td colspan="4">无数据</td>
</tr>
{% endif %}
</tbody>
</table>
<!-- 分页开始 -->
<div>
<ul class="pagination">
<li><a href="/console/announcement?page=1">首页</a></li>
{% if paginator.has_previous %}
<li><a href="/console/announcement?page={{ paginator.previous_page_number }}">上一页</a></li>
{% endif %}
{% for num in paginator.paginator.page_range %}
<li><a href="/console/announcement?page={{ num }}">{{ num }}</a></li>
{% endfor %}
{% if paginator.has_next %}
<li><a href="/console/announcement?page={{ paginator.next_page_number }}">下一页</a></li>
{% endif %}
<li><a href="/console/announcement?page={{ paginator.paginator.num_pages }}">尾页</a></li>
</ul>
</div>
<!-- 分页结束 -->
</body>
</html>
效果
About
了解更多有趣的操作请关注我的微信公众号:DealiAxy 每一篇文章都在我的博客有收录:blog.deali.cn