Django实战教程 分页列表
當用戶登錄成功后,首先看到的是他自己之前提交的任務列表,本篇將實現該頁面。
視圖(views.py)里定義如下:
from django.core.paginator import Paginator, PageNotAnInteger, EmptyPage
@login_required
def tasklist(request):
? ? username=request.user.username
? ? if len(Dba.objects.filter(username=username)) == 0: #User is not DBA, only shows his/her own tasklist
? ? ? ? userid=User.objects.filter(username=username)
? ? ? ? lines = Task.objects.filter(creater=userid).order_by("-id")
? ? else:? #User is DBA, shows all tasklist
? ? ? ? lines = Task.objects.order_by("-id")
? ? paginator = Paginator(lines, 10)
? ? page = request.GET.get('page')
? ? try:
? ? ? ? show_lines = paginator.page(page)
? ? except PageNotAnInteger:
? ? ? ? # If page is not an integer, deliver first page.
? ? ? ? show_lines = paginator.page(1)
? ? except EmptyPage:
? ? ? ? # If page is out of range (e.g. 9999), deliver last page of results.
? ? ? ? show_lines = paginator.page(paginator.num_pages)
? ? return render_to_response('tasklist.html', RequestContext(request, {'lines': show_lines,}))
該視圖的業務邏輯如下:
1)判斷用戶名,如果是普通用戶,只顯示他自己的任務列表;如果是DBA,則顯示所有用戶的任務列表。(從Task模型中獲取數據)
2)調用Bootstrap的分頁器Paginator,每頁顯示10行。
最終,該視圖返回模板tasklist.html,其定義如下:
{% extends "base.html" %}
{% load bootstrap_toolkit %}
{% block content %}
? ? <h1>任務列表</h1>
? ? <table class="table table-striped table-hover">
? ? ? ? <tr>
? ? ? ? ? ? <td><strong>ID</strong></td>
? ? ? ? ? ? <td><strong>提交者</strong></td>
? ? ? ? ? ? <td><strong>創建時間</strong></td>
? ? ? ? ? ? <td><strong>最后更新時間</strong></td>
? ? ? ? ? ? <td><strong>狀態</strong></td>
? ? ? ? </tr>
? ? ? ? {% for line in lines %}
? ? ? ? ? ? <tr>
? ? ? ? ? ? ? ? <td><a href="{% url 'dbrelease_app.views.taskdetail' %}?taskid={{ line.id }}">{{ line.id }}</a></td>
? ? ? ? ? ? ? ? <td><a href="{% url 'dbrelease_app.views.taskdetail' %}?taskid={{ line.id }}">{{ line.creater.last_name }}{{ line.creater.first_name }}</a></td>
? ? ? ? ? ? ? ? <td><a href="{% url 'dbrelease_app.views.taskdetail' %}?taskid={{ line.id }}">{{ line.createdtime|date:"Y-m-d H:i:s" }}</a></td>
? ? ? ? ? ? ? ? <td><a href="{% url 'dbrelease_app.views.taskdetail' %}?taskid={{ line.id }}">{{ line.lastupdatedtime|date:"Y-m-d H:i:s" }}</a></td>
? ? ? ? ? ? ? ? <td><a href="{% url 'dbrelease_app.views.taskdetail' %}?taskid={{ line.id }}">{{ line.state }}</a></td>
? ? ? ? ? ? </tr>
? ? ? ? ? ? </a>
? ? ? ? {% endfor %}
? ? </table>
? ? {% bootstrap_pagination lines url="/tasklist?page=1" align="center" size="large" %}
{% endblock %}
上面的模板定義了5列(分別是ID、提交者、創建時間、最后更新時間和狀態),每行上都加一個超鏈接,指向該Task的詳細信息(對應的視圖taskdetail,我們會在下一章講述該視圖)。
?
最終效果如下:
總結
以上是生活随笔為你收集整理的Django实战教程 分页列表的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Django分页的基本实现办法
- 下一篇: django中的分页