Django如何自定义分页


Posted in Python onSeptember 25, 2018

本文实例为大家分享了Django自定义分页的具体代码,供大家参考,具体内容如下

稳扎稳打版

def book(request):
 # 从URL取参数(访问的页码)
 page_num = request.GET.get("page")
 try:
 # 将取出的page转换为int类型
 page_num = int(page_num)
 except Exception as e:
 # 当输入的页码不是正经数字的时候 默认返回第一页的数据
 page_num = 1

 # 数据库总数据是多少条
 total_count = models.Book.objects.all().count()

 # 每一页显示多少条数据
 per_page = 10

 # 总共需要多少页码来展示
 total_page, m = divmod(total_count, per_page)
 if m:
 total_page += 1

 # 如果输入的页码数超过了最大的页码数,默认返回最后一页
 if page_num > total_page:
 page_num = total_page

 # 定义两个变量从哪里开始到哪里结束
 data_start = (page_num - 1) * 10
 data_end = page_num * 10

 # 页面上总共展示多少页码
 max_page = 11
 if total_page < max_page:
 max_page = total_page

 # 把从URL中获取的page_num 当做是显示页面的中间值, 那么展示的便是当前page_num 的前五页和后后五页
 half_max_page = max_page // 2
 # 根据展示的总页码算出页面上展示的页码从哪儿开始
 page_start = page_num - half_max_page
 # 根据展示的总页码算出页面上展示的页码到哪儿结束
 page_end = page_num + half_max_page

 # 如果当前页减一半 比1还小, 不然页面上会显示负数的页码
 if page_start <= 1:
 page_start = 1
 page_end = max_page
 # 如果 当前页 加 一半 比总页码数还大, 不然页面上会显示比总页码还大的多余页码
 if page_end >= total_page:
 page_end = total_page
 page_start = total_page - max_page + 1

 # 从数据库取值, 并按照起始数据到结束数据展示
 all_book = models.Book.objects.all()[data_start:data_end]


 # 自己拼接分页的HTML代码
 html_str_list = []

 # # 加上首页
 html_str_list.append('<li><a href="/book/?page=1" rel="external nofollow" >首页</a></li>')

 # 断一下 如果是第一页,就没有上一页
 if page_num <= 1:
 html_str_list.append('<li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" ><span aria-hidden="true">«</span></a></li>')
 else:
 # 不是第一页,就加一个上一页的标签
 html_str_list.append('<li><a href="/book/?page={}" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><span aria-hidden="true">«</span></a></li>'.format(page_num - 1))

 for i in range(page_start, page_end + 1):
 # 如果是当前页就加一个active样式类
 if i == page_num:
  tmp = '<li class="active"><a href="/book/?page={0}" rel="external nofollow" rel="external nofollow" >{0}</a></li>'.format(i)
 else:
  tmp = '<li><a href="/book/?page={0}" rel="external nofollow" rel="external nofollow" >{0}</a></li>'.format(i)

 html_str_list.append(tmp)

 # 判断,如果是最后一页,就没有下一页
 if page_num >= total_page:
 html_str_list.append('<li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" ><span aria-hidden="true">»</span></a></li>')
 else:
 # 不是最后一页, 就加一个下一页标签
 html_str_list.append('<li><a href="/book/?page={}" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><span aria-hidden="true">»</span></a></li>'.format(page_num + 1))

 # 加上尾页
 html_str_list.append('<li><a href="/book/?page={}" rel="external nofollow" rel="external nofollow" rel="external nofollow" >尾页</a></li>'.format(total_page))

 page_html = "".join(html_str_list)
 return render(request, "book.html", {"all_book":all_book, "page_html":page_html})

book.html

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>书籍列表</title>
 <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
</head>
<body>
<div class="container">
<table class="table table-bordered">
 <thead>
 <tr>
  <th>序列号</th>
  <th>ID值</th>
  <th>书名</th>
  <th>时间</th>
 </tr>
 {% for book in all_book %}
 <tr>
  <td>{{ forloop.counter }}</td>
  <td>{{ book.id }}</td>
  <td>{{ book.name }}</td>
  <td>{{ book.date }}</td>
 </tr>
 {% endfor %}
 </thead>
</table>
<nav aria-label="Page navigation">
 <ul class="pagination">
 {{ page_html|safe }}
 </ul>
</nav>
</div>
</body>
</html>

封装保存版

封装保存版

class Page(object):
 def __init__(self, page_num, total_count, url_prefix, per_page=10, max_page=11):
 """
 :param page_num: 当前页码数
 :param total_count: 数据总数
 :param url_prefix: a标签href的前缀
 :param per_page: 每页显示多少条数据
 :param max_page: 页面上最多显示几个页码
 """
 self.url_prefix = url_prefix
 self.max_page = max_page
 # 总共需要多少页码来展示
 total_page, m = divmod(total_count, per_page)
 if m:
  total_page += 1
 self.total_page = total_page

 try:
  # 将取出的page转换为int类型
  page_num = int(page_num)
 except Exception as e:
  # 当输入的页码不是正经数字的时候 默认返回第一页的数据
  page_num = 1
 # 如果输入的页码数超过了最大的页码数,默认返回最后一页
 if page_num > total_page:
  page_num = total_page
 self.page_num = page_num

 # 定义两个变量保存数据从哪儿取到哪儿
 self.data_start = (page_num - 1) * 10
 self.data_end = page_num * 10

 # 页面上总共展示多少页码
 if total_page < self.max_page:
  self.max_page = total_page

 half_max_page = self.max_page // 2
 # 页面上展示的页码从哪儿开始
 page_start = page_num - half_max_page
 # 页面上展示的页码到哪儿结束
 page_end = page_num + half_max_page
 # 如果当前页减一半 比1还小, 不然页面上会显示负数的页码
 if page_start <= 1:
  page_start = 1
  page_end = self.max_page
 # 如果 当前页 加 一半 比总页码数还大, 不然页面上会显示比总页码还大的多余页码
 if page_end >= total_page:
  page_end = total_page
  page_start = total_page - self.max_page + 1
 self.page_start = page_start
 self.page_end = page_end

 @property
 def start(self):
 return self.data_start

 @property
 def end(self):
 return self.data_end

 def page_html(self):
 # 自己拼接分页的HTML代码
 html_str_list = []
 # # 加上首页
 html_str_list.append('<li><a href="{}?page=1">首页</a></li>'.format(self.url_prefix))
 # 断一下 如果是第一页,就没有上一页
 if self.page_num <= 1:
  html_str_list.append('<li class="disabled"><a href="#"><span aria-hidden="true">«</span></a></li>')
 else:
  # 不是第一页,就加一个上一页的标签
  html_str_list.append('<li><a href="{}?page={}"><span aria-hidden="true">«</span></a></li>'.format(self.url_prefix, self.page_num - 1))

 for i in range(self.page_start, self.page_end + 1):
  # 如果是当前页就加一个active样式类
  if i == self.page_num:
  tmp = '<li class="active"><a href="{0}?page={1}">{1}</a></li>'.format(self.url_prefix, i)
  else:
  tmp = '<li><a href="{0}?page={1}">{1}</a></li>'.format(self.url_prefix, i)

  html_str_list.append(tmp)

 # 判断,如果是最后一页,就没有下一页
 if self.page_num >= self.total_page:
  html_str_list.append('<li class="disabled"><a href="#"><span aria-hidden="true">»</span></a></li>')
 else:
  # 不是最后一页, 就加一个下一页标签
  html_str_list.append('<li><a href="{}?page={}"><span aria-hidden="true">»</span></a></li>'.format(self.url_prefix, self.page_num + 1))

 # 加上尾页
 html_str_list.append('<li><a href="{}?page={}">尾页</a></li>'.format(self.url_prefix, self.total_page))

 page_html = "".join(html_str_list)
 return page_html

封装版使用指南

def publisher(request):
 page_num = request.GET.get("page")
 total_count = models.Publisher.objects.all().count()
 # 调用封装的Page类,传入相应的参数
 page_obj = Page(page_num, total_count, url_prefix="/publisher/", per_page=10, max_page=11)
 all_publisher = models.Publisher.objects.all()[page_obj.start:page_obj.end]
 page_html = page_obj.page_html()
 return render(request, "publisher.html", {"publisher": all_publisher, "page_html": page_html})

封装版对应的HTML参考

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>图书列表</title>
 <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
</head>
<body>
<div class="container">
 <table class="table table-bordered">
 <thead>
 <tr>
  <td>序列号</td>
  <td>ID值</td>
  <td>出版社</td>
  <td>时间</td>
 </tr>
 </thead>
 <tbody>
 {% for pub in publisher %}
  <tr>
  <th>{{ forloop.counter }}</th>
  <th>{{ pub.id }}</th>
  <th>{{ pub.name }}</th>
  <th>{{ pub.date }}</th>
  </tr>
 {% endfor %}
 </tbody>
 </table>
 <nav aria-label="Page navigation">
 <ul class="pagination">
  {{ page_html|safe }}
 </ul>
 </nav>
</div>
</body>
</html>

效果图如下:

Django如何自定义分页

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python实现从一组颜色中找出与给定颜色最接近颜色的方法
Mar 19 Python
用map函数来完成Python并行任务的简单示例
Apr 02 Python
wxPython中listbox用法实例详解
Jun 01 Python
关于Python中Inf与Nan的判断问题详解
Feb 08 Python
Python使用flask框架操作sqlite3的两种方式
Jan 31 Python
python sys.argv[]用法实例详解
May 25 Python
python实现nao机器人身体躯干和腿部动作操作
Apr 29 Python
使用Python的Turtle绘制哆啦A梦实例
Nov 21 Python
python实现图像拼接功能
Mar 23 Python
pycharm工具连接mysql数据库失败问题
Apr 01 Python
浅谈anaconda python 版本对应关系
Oct 07 Python
Python eval函数原理及用法解析
Nov 14 Python
Python使用googletrans报错的解决方法
Sep 25 #Python
Python实现简单的用户交互方法详解
Sep 25 #Python
Python中反射和描述器总结
Sep 23 #Python
python3实现爬取淘宝美食代码分享
Sep 23 #Python
ubuntu16.04制作vim和python3的开发环境
Sep 23 #Python
Python实现注册、登录小程序功能
Sep 21 #Python
用于业余项目的8个优秀Python库
Sep 21 #Python
You might like
探讨PHP调用时间格式的参数详解
2013/06/06 PHP
PHP中HTML标签过滤技巧
2014/01/07 PHP
CI框架给视图添加动态数据
2014/12/01 PHP
phpstorm 正则匹配删除空行、注释行(替换注释行为空行)
2018/01/21 PHP
网页自动刷新,不产生嗒嗒声的一个解决方法
2007/03/27 Javascript
js事件冒泡实例分享(已测试)
2013/04/23 Javascript
JavaScript实现数字数组按照倒序排列的方法
2015/04/06 Javascript
详解JavaScript中的4种类型识别方法
2015/09/14 Javascript
zTree插件下拉树使用入门教程
2016/04/11 Javascript
浅析JS动态创建元素【两种方法】
2016/04/20 Javascript
Wireshark基本介绍和学习TCP三次握手
2016/08/15 Javascript
微信小程序 扎金花简单实例
2017/02/21 Javascript
jQuery动态移除和添加背景图片的方法详解
2017/03/07 Javascript
JavaScript仿微信打飞机游戏
2020/07/05 Javascript
JavaScript中AOP的实现与应用
2019/05/06 Javascript
egg.js的基本使用和调用数据库的方法示例
2019/05/18 Javascript
vue 实现通过vuex 存储值 在不同界面使用
2019/11/11 Javascript
nodejs处理tcp连接的核心流程
2021/02/26 NodeJs
[01:54]胎教DOTA2 准妈妈玩家现身中国区预选赛
2016/06/26 DOTA
[01:06:59]完美世界DOTA2联赛PWL S2 Magma vs FTD 第一场 11.29
2020/12/02 DOTA
Python抽象类的新写法
2015/06/18 Python
Python中文分词工具之结巴分词用法实例总结【经典案例】
2017/04/15 Python
Django 忘记管理员或忘记管理员密码 重设登录密码的方法
2018/05/30 Python
Python模拟浏览器上传文件脚本的方法(Multipart/form-data格式)
2018/10/22 Python
Python推导式简单示例【列表推导式、字典推导式与集合推导式】
2018/12/04 Python
Python基础之条件控制操作示例【if语句】
2019/03/23 Python
jupyter notebook 重装教程
2020/04/16 Python
Anaconda+vscode+pytorch环境搭建过程详解
2020/05/25 Python
婴儿鞋,独特的婴儿服装和配件:Zutano
2018/11/03 全球购物
Brother加拿大官网:打印机、贴标机、缝纫机
2019/10/09 全球购物
Simons官方网站:加拿大时尚零售商
2020/02/20 全球购物
中学教师个人总结
2015/02/10 职场文书
活动宣传稿范文
2015/07/23 职场文书
Go 实现英尺和米的简单单位换算方式
2021/04/29 Golang
详解Redis的三种常用的缓存读写策略步骤
2022/05/06 Redis
python缺失值填充方法示例代码
2022/12/24 Python