[Django实战] 第8篇 - 分页列表

当用户登录成功后,首先看到的是他自己之前提交的任务列表,本篇将实现该页面。

视图(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,我们会在下一章讲述该视图)。

最终效果如下:




  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值