经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Python » 查看文章
Django自定义分页别来无恙-
来源:cnblogs  作者:别来无恙-  时间:2018/9/25 20:36:27  对本文有异议

分页

自定义分页

稳扎稳打版

  1. def book(request):
  2. # 从URL取参数(访问的页码)
  3. page_num = request.GET.get("page")
  4. try:
  5. # 将取出的page转换为int类型
  6. page_num = int(page_num)
  7. except Exception as e:
  8. # 当输入的页码不是正经数字的时候 默认返回第一页的数据
  9. page_num = 1
  10.  
  11. # 数据库总数据是多少条
  12. total_count = models.Book.objects.all().count()
  13. # 每一页显示多少条数据
  14. per_page = 10
  15.  
  16. # 总共需要多少页码来展示
  17. total_page, m = divmod(total_count, per_page)
  18. if m:
  19. total_page += 1
  20.  
  21. # 如果输入的页码数超过了最大的页码数,默认返回最后一页
  22. if page_num > total_page:
  23. page_num = total_page
  24. # 定义两个变量从哪里开始到哪里结束
  25. data_start = (page_num - 1) * 10
  26. data_end = page_num * 10
  27.  
  28. # 页面上总共展示多少页码
  29. max_page = 11
  30. if total_page < max_page:
  31. max_page = total_page
  32. # 把从URL中获取的page_num 当做是显示页面的中间值, 那么展示的便是当前page_num 的前五页和后后五页
  33. half_max_page = max_page // 2
  34. # 根据展示的总页码算出页面上展示的页码从哪儿开始
  35. page_start = page_num - half_max_page
  36. # 根据展示的总页码算出页面上展示的页码到哪儿结束
  37. page_end = page_num + half_max_page
  38. # 如果当前页减一半 比1还小, 不然页面上会显示负数的页码
  39. if page_start <= 1:
  40. page_start = 1
  41. page_end = max_page
  42. # 如果 当前页 加 一半 比总页码数还大, 不然页面上会显示比总页码还大的多余页码
  43. if page_end >= total_page:
  44. page_end = total_page
  45. page_start = total_page - max_page + 1
  46.  
  47. # 从数据库取值, 并按照起始数据到结束数据展示
  48. all_book = models.Book.objects.all()[data_start:data_end]
  49. # 自己拼接分页的HTML代码
  50. html_str_list = []
  51. # # 加上首页
  52. html_str_list.append('<li><a href="/book/?page=1">首页</a></li>')
  53. # 断一下 如果是第一页,就没有上一页
  54. if page_num <= 1:
  55. html_str_list.append('<li class="disabled"><a href="#"><span aria-hidden="true">&laquo;</span></a></li>')
  56. else:
  57. # 不是第一页,就加一个上一页的标签
  58. html_str_list.append('<li><a href="/book/?page={}"><span aria-hidden="true">&laquo;</span></a></li>'.format(page_num - 1))
  59. for i in range(page_start, page_end + 1):
  60. # 如果是当前页就加一个active样式类
  61. if i == page_num:
  62. tmp = '<li class="active"><a href="/book/?page={0}">{0}</a></li>'.format(i)
  63. else:
  64. tmp = '<li><a href="/book/?page={0}">{0}</a></li>'.format(i)
  65. html_str_list.append(tmp)
  66. # 判断,如果是最后一页,就没有下一页
  67. if page_num >= total_page:
  68. html_str_list.append('<li class="disabled"><a href="#"><span aria-hidden="true">&raquo;</span></a></li>')
  69. else:
  70. # 不是最后一页, 就加一个下一页标签
  71. html_str_list.append('<li><a href="/book/?page={}"><span aria-hidden="true">&raquo;</span></a></li>'.format(page_num + 1))
  72. # 加上尾页
  73. html_str_list.append('<li><a href="/book/?page={}">尾页</a></li>'.format(total_page))
  74. page_html = "".join(html_str_list)
  75. return render(request, "book.html", {"all_book":all_book, "page_html":page_html})
稳扎稳打版
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>书籍列表</title>
  6. <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
  7. </head>
  8. <body>
  9. <div class="container">
  10. <table class="table table-bordered">
  11. <thead>
  12. <tr>
  13. <th>序列号</th>
  14. <th>ID值</th>
  15. <th>书名</th>
  16. <th>时间</th>
  17. </tr>
  18. {% for book in all_book %}
  19. <tr>
  20. <td>{{ forloop.counter }}</td>
  21. <td>{{ book.id }}</td>
  22. <td>{{ book.name }}</td>
  23. <td>{{ book.date }}</td>
  24. </tr>
  25. {% endfor %}
  26. </thead>
  27. </table>
  28. <nav aria-label="Page navigation">
  29. <ul class="pagination">
  30. {{ page_html|safe }}
  31. </ul>
  32. </nav>
  33. </div>
  34. </body>
  35. </html>
book.html

封装保存版

  1. class Page(object):
  2. def __init__(self, page_num, total_count, url_prefix, per_page=10, max_page=11):
  3. """
  4. :param page_num: 当前页码数
  5. :param total_count: 数据总数
  6. :param url_prefix: a标签href的前缀
  7. :param per_page: 每页显示多少条数据
  8. :param max_page: 页面上最多显示几个页码
  9. """
  10. self.url_prefix = url_prefix
  11. self.max_page = max_page
  12. # 总共需要多少页码来展示
  13. total_page, m = divmod(total_count, per_page)
  14. if m:
  15. total_page += 1
  16. self.total_page = total_page
  17. try:
  18. # 将取出的page转换为int类型
  19. page_num = int(page_num)
  20. except Exception as e:
  21. # 当输入的页码不是正经数字的时候 默认返回第一页的数据
  22. page_num = 1
  23. # 如果输入的页码数超过了最大的页码数,默认返回最后一页
  24. if page_num > total_page:
  25. page_num = total_page
  26. self.page_num = page_num
  27. # 定义两个变量保存数据从哪儿取到哪儿
  28. self.data_start = (page_num - 1) * 10
  29. self.data_end = page_num * 10
  30.  
  31. # 页面上总共展示多少页码
  32. if total_page < self.max_page:
  33. self.max_page = total_page
  34. half_max_page = self.max_page // 2
  35. # 页面上展示的页码从哪儿开始
  36. page_start = page_num - half_max_page
  37. # 页面上展示的页码到哪儿结束
  38. page_end = page_num + half_max_page
  39. # 如果当前页减一半 比1还小, 不然页面上会显示负数的页码
  40. if page_start <= 1:
  41. page_start = 1
  42. page_end = self.max_page
  43. # 如果 当前页 加 一半 比总页码数还大, 不然页面上会显示比总页码还大的多余页码
  44. if page_end >= total_page:
  45. page_end = total_page
  46. page_start = total_page - self.max_page + 1
  47. self.page_start = page_start
  48. self.page_end = page_end
  49. @property
  50. def start(self):
  51. return self.data_start
  52. @property
  53. def end(self):
  54. return self.data_end
  55. def page_html(self):
  56. # 自己拼接分页的HTML代码
  57. html_str_list = []
  58. # # 加上首页
  59. html_str_list.append('<li><a href="{}?page=1">首页</a></li>'.format(self.url_prefix))
  60. # 断一下 如果是第一页,就没有上一页
  61. if self.page_num <= 1:
  62. html_str_list.append('<li class="disabled"><a href="#"><span aria-hidden="true">&laquo;</span></a></li>')
  63. else:
  64. # 不是第一页,就加一个上一页的标签
  65. html_str_list.append('<li><a href="{}?page={}"><span aria-hidden="true">&laquo;</span></a></li>'.format(self.url_prefix, self.page_num - 1))
  66. for i in range(self.page_start, self.page_end + 1):
  67. # 如果是当前页就加一个active样式类
  68. if i == self.page_num:
  69. tmp = '<li class="active"><a href="{0}?page={1}">{1}</a></li>'.format(self.url_prefix, i)
  70. else:
  71. tmp = '<li><a href="{0}?page={1}">{1}</a></li>'.format(self.url_prefix, i)
  72. html_str_list.append(tmp)
  73. # 判断,如果是最后一页,就没有下一页
  74. if self.page_num >= self.total_page:
  75. html_str_list.append('<li class="disabled"><a href="#"><span aria-hidden="true">&raquo;</span></a></li>')
  76. else:
  77. # 不是最后一页, 就加一个下一页标签
  78. html_str_list.append('<li><a href="{}?page={}"><span aria-hidden="true">&raquo;</span></a></li>'.format(self.url_prefix, self.page_num + 1))
  79. # 加上尾页
  80. html_str_list.append('<li><a href="{}?page={}">尾页</a></li>'.format(self.url_prefix, self.total_page))
  81. page_html = "".join(html_str_list)
  82. return page_html
封装保存版
  1. def publisher(request):
  2. page_num = request.GET.get("page")
  3. total_count = models.Publisher.objects.all().count()
  4. # 调用封装的Page类,传入相应的参数
  5. page_obj = Page(page_num, total_count, url_prefix="/publisher/", per_page=10, max_page=11)
  6. all_publisher = models.Publisher.objects.all()[page_obj.start:page_obj.end]
  7. page_html = page_obj.page_html()
  8. return render(request, "publisher.html", {"publisher": all_publisher, "page_html": page_html})
封装版使用指南
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>图书列表</title>
  6. <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
  7. </head>
  8. <body>
  9. <div class="container">
  10. <table class="table table-bordered">
  11. <thead>
  12. <tr>
  13. <td>序列号</td>
  14. <td>ID值</td>
  15. <td>出版社</td>
  16. <td>时间</td>
  17. </tr>
  18. </thead>
  19. <tbody>
  20. {% for pub in publisher %}
  21. <tr>
  22. <th>{{ forloop.counter }}</th>
  23. <th>{{ pub.id }}</th>
  24. <th>{{ pub.name }}</th>
  25. <th>{{ pub.date }}</th>
  26. </tr>
  27. {% endfor %}
  28. </tbody>
  29. </table>
  30. <nav aria-label="Page navigation">
  31. <ul class="pagination">
  32. {{ page_html|safe }}
  33. </ul>
  34. </nav>
  35. </div>
  36. </body>
  37. </html>
封装版对应的HTML参考

效果图如下:

 

 

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

本站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号