经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Django » 查看文章
Django框架实现的简单分页功能示例
来源:jb51  时间:2018/12/5 9:22:41  对本文有异议

本文实例讲述了Django框架实现的简单分页功能。分享给大家供大家参考,具体如下:

前面一篇《Django开发的简易留言板》写了个简单的留言板,如果数据量太多的话在一页显示就不那么友好了,本文就是做一个分页显示。

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

导入分页模块并修改views

  1. #只需修改index函数即可
  2. from django.core.paginator import Paginator
  3. def index(request):
  4. messages = models.Message.objects.all() #获取全部数据
  5. limit = 10
  6. paginator = Paginator(messages, limit) #按每页10条分页
  7. page = request.GET.get('page','1') #默认跳转到第一页
  8. result = paginator.page(page)
  9. return render(request, 'guestbook/index.html', {'messages' : result})
  10.  

修改html

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8" />
  5. <title>留言板</title>
  6. <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" crossorigin="anonymous">
  7. </head>
  8. <body>
  9. <table class="table table-striped table-bordered table-hover table-condensed">
  10. <thead>
  11. <tr class="danger">
  12. <th>留言时间</th>
  13. <th>留言者</th>
  14. <th>标题</th>
  15. <th>内容</th>
  16. </tr>
  17. </thead>
  18. <tbody>
  19. {% if messages %}
  20. {% for message in messages %}
  21. <tr class="{% cycle 'active' 'success' 'warning' 'info' %}">
  22. <td>{{ message.publish|date:'Y-m-d H:i:s' }}</td>
  23. <td>{{ message.username }}</td>
  24. <td>{{ message.title }}</td>
  25. <td>{{ message.content }}</td>
  26. </tr>
  27. {% endfor %}
  28. {% else %}
  29. <tr>
  30. <td colspan="4">无数据</td>
  31. </tr>
  32. {% endif %}
  33. </tbody>
  34. </table>
  35. <!-- 分页开始 -->
  36. <div>
  37. <ul class="pagination">
  38. <li><a href="/guestbook/index/?page=1" rel="external nofollow" >首页</a></li>
  39. {% if messages.has_previous %}
  40. <li><a href="/guestbook/index/?page={{ messages.previous_page_number }}" rel="external nofollow" >上一页</a></li>
  41. {% endif %}
  42. {% for num in messages.paginator.page_range %}
  43. <li><a href="/guestbook/index/?page={{ num }}" rel="external nofollow" >{{ num }}</a></li>
  44. {% endfor %}
  45. {% if messages.has_next %}
  46. <li><a href="/guestbook/index/?page={{ messages.next_page_number }}" rel="external nofollow" >下一页</a></li>
  47. {% endif %}
  48. <li><a href="/guestbook/index/?page={{ messages.paginator.num_pages }}" rel="external nofollow" >尾页</a></li>
  49. </ul>
  50. </div>
  51. <!-- 分页结束 -->
  52. <div>
  53. <a class="btn btn-xs btn-primary" href="/guestbook/create/" rel="external nofollow" >去留言</a>
  54. </div>
  55. </body>
  56. </html>
  57.  

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

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号