1. 程式人生 > >Django實戰教程 分頁列表

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,我們會在下一章講述該檢視)。

最終效果如下:

linux