使用Django实现分页功能

本文介绍如何在Django项目中实现分页功能,基于上一个简单的留言板应用进行改进。通过导入分页模块和修改视图及HTML,利用Django的Paginator模块,实现了数据量大的情况下更友好的页面展示。读者可以通过官方文档进一步了解该模块的强大功能,并可结合ListView简化分页代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

上一个博客写了个简单的留言板,如果数据量太多的话在一页显示就不那么友好了,本文就是做一个分页显示。

代码在上一篇的基础上修改。

导入分页模块并修改views

#只需修改index函数即可
from django.core.paginator import Paginator
def index(request):
    messages = models.Message.objects.all()  #获取全部数据
    limit = 10
    paginator = Paginator(messages, limit)  #按每页10条分页
    page = request.GET.get('page','1')  #默认跳转到第一页

    result = paginator.page(page) 

    return render(request, 'guestbook/index.html', {'messages' : result})

修改html

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title>留言板</title>
        <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" crossorigin="anonymous">
    </head>
    <body>

        <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 messages %}
                    {% for message in messages %}
                        <tr class="{% cycle 'active' 'success' 'warning' 'info' %}">
                            <td>{{ message.publish|date:'Y-m-d H:i:s' }}</td>
                            <td>{{ message.username }}</td>
                            <td>{{ message.title }}</td>
                            <td>{{ message.content }}</td>
                        </tr>
                    {% endfor %}
                {% else %}
                    <tr>
                        <td colspan="4">无数据</td>
                    </tr>
                {% endif %}
            </tbody>
        </table>

        <!-- 分页开始 -->
        <div>
            <ul class="pagination">
            <li><a href="/guestbook/index/?page=1">首页</a></li>
                 {% if messages.has_previous %}
                        <li><a href="/guestbook/index/?page={{ messages.previous_page_number }}">上一页</a></li>
                {% endif %}

                 {% for num in messages.paginator.page_range %}
                    <li><a href="/guestbook/index/?page={{ num }}">{{ num }}</a></li>
                 {% endfor %}

                {% if messages.has_next %}
                     <li><a href="/guestbook/index/?page={{ messages.next_page_number }}">下一页</a></li>
                {% endif %}
                <li><a href="/guestbook/index/?page={{ messages.paginator.num_pages }}">尾页</a></li>
             </ul>
        </div>
        <!-- 分页结束 -->

        <div>
             <a class="btn btn-xs btn-primary" href="/guestbook/create/">去留言</a>
        </div>
    </body>
</html>

其实主要使用了Django自带的Paginator模块,关于这个模块大家可以自己去官方文档查看,功能还是挺强大的,如果配合ListView的话,三行代码就可以实现分页功能。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值