日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Django实战教程 分页列表

發布時間:2025/6/15 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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实战教程 分页列表的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。