神剑山庄资源网 Design By www.hcban.com
本文实例讲述了Django框架实现的简单分页功能。分享给大家供大家参考,具体如下:
前面一篇《Django开发的简易留言板》写了个简单的留言板,如果数据量太多的话在一页显示就不那么友好了,本文就是做一个分页显示。
代码在上一篇的基础上修改。
导入分页模块并修改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" rel="external nofollow" 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/" rel="external nofollow" >首页</a></li> {% if messages.has_previous %} <li><a href="/guestbook/index/" rel="external nofollow" >上一页</a></li> {% endif %} {% for num in messages.paginator.page_range %} <li><a href="/guestbook/index/" rel="external nofollow" >{{ num }}</a></li> {% endfor %} {% if messages.has_next %} <li><a href="/guestbook/index/" rel="external nofollow" >下一页</a></li> {% endif %} <li><a href="/guestbook/index/" rel="external nofollow" >尾页</a></li> </ul> </div> <!-- 分页结束 --> <div> <a class="btn btn-xs btn-primary" href="/guestbook/create/" rel="external nofollow" >去留言</a> </div> </body> </html>
其实主要使用了Django自带的Paginator模块,关于这个模块大家可以自己去官方文档查看,功能还是挺强大的,如果配合ListView的话,三行代码就可以实现分页功能。
希望本文所述对大家基于Django框架的Python程序设计有所帮助。
标签:
Django,分页
神剑山庄资源网 Design By www.hcban.com
神剑山庄资源网
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
神剑山庄资源网 Design By www.hcban.com
暂无Django框架实现的简单分页功能示例的评论...
更新日志
2024年10月02日
2024年10月02日
- 孙悦.1996-伙伴【正大国际】【WAV+CUE】
- 纪钧瀚《钢琴阅读时光 雨中书店聆听轻音乐》[FLAC/分轨][399.62MB]
- 证声音乐图书馆《走向自然 疗心爵士乐》[320K/MP3][87.4MB]
- 证声音乐图书馆《走向自然 疗心爵士乐》[FLAC/分轨][184.94MB]
- 陈慧娴.2018-Priscilla-Ism演唱会3CD(2024环球红馆40复刻系列)【环球】【WAV+CUE】
- 郑秀文.1999-我应该得到(国)【华纳】【WAV+CUE】
- 陈家慧.2011-钢琴酒吧2CD【龙吟唱片】【WAV+CUE】
- 证声音乐图书馆《雨季 蓝调吉他 Rainy Blues》[320K/MP3][45.01MB]
- 证声音乐图书馆《雨季 蓝调吉他 Rainy Blues》[FLAC/分轨][109.13MB]
- 赞多《序章》[320K/MP3][45.54MB]
- 许巍.2004-每一刻都是崭新的【步升大风】【WAV+CUE】
- 群星.2024-四方馆影视原声带【韶愔音乐】【FLAC分轨】
- 陈雷.1997-安锁咧【金圆唱片】【WAV+CUE】
- 关淑怡.2013-MY.FAVORITE.SK.3CD【环球】【WAV+CUE】
- Sweety.2006-花言乔语【丰华】【WAV+CUE】