Django中已经实现了很多功能,基本上只要我们需要的功能,都能够找到相应的包。要在Django中实现分页显示,只需要简单地使用Paginator就可以实现了。

首先,需要在应用的views.py中添加如下引用:

from django.core.paginator import Paginatorfrom django.core.paginator import PageNotAnIntegerfrom django.core.paginator import EmptyPage

然后,在需要使用分页的view函数中,添加如下代码:

blogs = Blog.objects.all() # Get released blogspaginator = Paginator(blogs, 8)try:blogs = paginator.page(page_num)except PageNotAnInteger:blogs = paginator.page(1)except EmptyPage:blogs = paginator.page(paginator.num_pages)

以上代码中,page_num是指的当前需要显示的页,要将当前页的内容显示出来,就跟使用原对象一样,基本没有什么区别,我们还是只需要像如下在模板中使用:

{% for blog in blogs %}{{ blog.name }}{{ blog.content }}......{% endfor %}

最后,为了显示分页导航信息,我们需要在模板中添加如下代码:

{% if blogs.has_previous %}<a class='paginator' title='上一页' href='?page={{ blogs.previous_page_number }}'><span>&lt;&lt;</span></a>{% endif %}{% for page in blogs.paginator.page_range %}{% if page = blogs.number %}<a class='paginator_current' title='当前页:{{ page }}'><span>{{ page }}</span></a>{% else %}<a class='paginator' href='?page={{ page }}' title='{{ page }}'><span>{{ page }}</span></a>{% endif %}{% endfor %}{% if blogs.has_next %}<a class='paginator' title='下一页' href='?page={{ blogs.next_page_number }}'><span>&gt;&gt;</span></a>{% endif %}

OK,一切就这么简单,对数据进行分页显示就完成了。

但是,等等,这里好像还有问题,如果我的数据很多,分出来的页面数也很多,那岂不是分页导航将显示很长的一串数字?

的确是这样,page_range根据总页数,返回从1到总页数之间在数字序列,例如总页数是5, 则page_range返回的值将是[1,2,3,4,5],以此类推,对我们来说的确是个问题。

正是因为有问题,因此也才有了我的博客,下面才是我真正的目的所在,扩展框架自带的Paginator,废话少说,直接上代码:

from django.core.paginator import Paginatorclass JuncheePaginator(Paginator):def __init__(self, object_list, per_page, range_num=5, orphans=0, allow_empty_first_page=True):Paginator.__init__(self, object_list, per_page, orphans, allow_empty_first_page)self.range_num = range_numdef page(self, number):self.page_num = numberreturn super(JuncheePaginator, self).page(number)def _page_range_ext(self):num_count = 2 * self.range_num + 1if self.num_pages <= num_count:return range(1, self.num_pages + 1)num_list = []num_list.append(self.page_num)for i in range(1, self.range_num + 1):if self.page_num - i <= 0:num_list.append(num_count + self.page_num - i)else:num_list.append(self.page_num - i)if self.page_num + i <= self.num_pages:num_list.append(self.page_num + i)else:num_list.append(self.page_num + i - num_count)num_list.sort()return num_listpage_range_ext = property(_page_range_ext)

为了减少文章篇幅,我特意将一些注释去掉了。现在简单地解释一 下。

__init__()函数不用说了吧,就是重载了一下,添加了一个range_num参数,代表在可能的情况下,当前页左右各显示多少个页标签,默认值为5。

page()函数是对父类Paginator的page()函数的重写,主要是为了记录当前页。

核心是_page_range_ext()函数,它实现了我们根据page_num的情况来返回恰当的页面列表,page_num取默认值的情况下,如果 当前页是8,则我们返回的页数列表就应该是[3,4,5,6,7,8,9,10,11,12,13],但如果说是当前页是2,则会返回 [1,2,3,4,5,6,7,8,9,10,11],其余的以此类推。具体算法我就不仔细分析了,大家可以参看源代码,个人感觉还可以优化,但我现在也 就能用就行。

接下来还需要在views.py中将以下语句:

paginator = Paginator(blogs, 8)

改为:

paginator = JuncheePaginator(blogs, 8)

在模板中,将以下语句:

{% for page in blogs.paginator.page_range %}

改为:

{% for page in blogs.paginator.page_range_ext %}

其它的事情,呵呵,那就是快去美化你的页面吧!

转载于:https://blog.51cto.com/1161192890/1638313

Django中扩展Paginator实现分页相关推荐

  1. Django中使用Pagination的分页范例源码

    将做工程过程重要的内容做个珍藏,下面代码内容是关于Django中使用Pagination的分页范例的代码. from django.core.paginator import Paginator ob ...

  2. django 高级扩展-中间件-上传图片-分页-富文本-celery

    """ django 高级扩展一.静态文件 1.css,js,json,图片,字体等 2.配置setting,在最底下设置静态文件目录,写入下面代码 #配置静态文件目录 ...

  3. Django中html里的分页显示

    分页一(very low) 因为数据量过大,而又想直观便捷的查看数据,进而通过分页显示就可以完成这项工作 app中views.py LIST=[] #全局定义一个LIST for i in range ...

  4. django中的分页

    分页在现在的网站应用中是非常用的,在Django 中要实现分页,是一件很简单的事情.使用Paginator,但是这种方法在小数据量,几百条时,可以使用.一旦数据大起来之后,效率就非常低下了.artic ...

  5. Django上传文件及分页

    Django上传文件及分页 文章目录 Django上传文件及分页 一.上传图片 二.在管理页面admin中上传图片 三.自定义form表单中上传图片 四.显示图片 五.分页 六.省市区案例 一.上传图 ...

  6. django 打开的html css_Django分页完整示例

    大家好,在这篇文章中,我们将展示django的分页完整的一个实例,当我们打算用Django中开发博客时,需要将帖子列表分别展示到多个页面上,在这方面,Django具有内置的分页类,可管理分页数据.所有 ...

  7. DJango 多条件查询结果分页

    为什么80%的码农都做不了架构师?>>>    在学习Django中,练手做了个项目,在实际编程当中发现了N多个坑,现在记录下心得体会,方便以后查询,本人Models只使用了一张表, ...

  8. Django中views笔记

    reverse反解析 1 #路由中定义namespace.name,reverse可将其转换为url 2 url = reverse('namespace:name') 3 return redire ...

  9. Django中Model模块的操作-创建各种表结构(上)

    Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLd ...

最新文章

  1. 人机融合智能:人工智能3.0
  2. 获取Moment Js中两个日期之间的小时差异
  3. 多层神经网络Java代码800行
  4. RabbitMQ—流控机制
  5. .NET6之MiniAPI(八):日志
  6. SpringBoot的整合————一些常用工具类依赖及用法总结
  7. Oracle11g x64使用Oracle SQL Developer报错:Unable to find a Java Virtual Machine
  8. 企业微信网页应用开发 - 权限验证
  9. STM32l151 使用滴答计时器精准延时1us,1ms
  10. 研究生研一学习机器学习ML、深度学习DL的规划
  11. SpringBoot + Thymeleaf 练手小项目 --------- 豆瓣网站模拟
  12. layui表格时间显示格式
  13. Hi,欢迎大家来到阿毛小猪的博客,分享自己学习中的经验,默默的前行,聆听心的声音...
  14. 不要悲观!勇敢面对逆境
  15. 田野调查手记·浮山摩崖石刻(九)
  16. linux scp连不上主机,如何使用WinSCP连接Linux主机
  17. 无穷级数的简单求解方法——高等数学
  18. 鸭子心包积液是怎么回事怎么治32天的鸭子心包积液是什么病
  19. 关于“尺蠖(huò)效应”
  20. 【小白CV教程】YOLOv5+Deepsort实现车辆行人的检测、追踪和计数

热门文章

  1. MySQL主键的理解
  2. eclipse开发cocos2dx 3.2环境搭建之二: cocos2dx 3.2安装及测试运行 (An internal error occurred during: “C/C++ Indexe)
  3. Java Spring MVC框架搭建(一)
  4. social-auth-app-django模块
  5. json学习系列(7)JSONBuilder的用法
  6. sql语句跨服务器跨数据库执行
  7. 第二单元作业——电梯模拟总结
  8. RedirectToAction()转移方式及参数传递
  9. 'weblogic.kernel.Default (self-tuning) 问题weblogic层面解决办法
  10. 系统调用syscall---用户态切换到内核态的唯一途径