侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Django如何自定义分页

框架(架构)  /  管理员 发布于 7年前   444

本文实例为大家分享了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="https: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="https: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="https:book/?page={0}" rel="external nofollow" rel="external nofollow" >{0}</a></li>'.format(i) else:  tmp = '<li><a href="https: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="https: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="https: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="https: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="https:/article/{}?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="https:/article/{}?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="https:/article/{0}?page={1}">{1}</a></li>'.format(self.url_prefix, i)  else:  tmp = '<li><a href="https:/article/{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="https:/article/{}?page={}"><span aria-hidden="true">»</span></a></li>'.format(self.url_prefix, self.page_num + 1)) # 加上尾页 html_str_list.append('<li><a href="https:/article/{}?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="https: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中使用定时任务的方法
    下一条:
    Django forms组件的使用教程
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Filament v3.1版本发布(0个评论)
    • docker + gitea搭建一个git服务器流程步骤(0个评论)
    • websocket的三种架构方式使用优缺点浅析(0个评论)
    • ubuntu20.4系统中宿主机安装nginx服务,docker容器中安装php8.2实现运行laravel10框架网站(0个评论)
    • phpstudy_pro(小皮面板)中安装最新php8.2.9版本流程步骤(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2018-05
    • 2020-02
    • 2020-03
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-11
    • 2021-03
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-08
    • 2023-08
    • 2023-10
    • 2023-12
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客