Django组件——分页器(paginator)
一、视图层
from django.shortcuts import render # Create your views here. from .models import Book
from django.core.paginator import Paginator,EmptyPage def index(request):
"""
# 批量导入数据
book_list=[]
for i in range(100):
book = Book.objects.create(title="book_%s" % i, price=i*i)
book_list.append(book)
Book.objects.bulk_create(book_list)
""" # 分页器的使用:
book_list = Book.objects.all() paginator = Paginator(book_list, 8) # 第二个参数设置每页显示的条数 print(paginator.count) # 数据总条数 100
print(paginator.num_pages) # 总页数 13
print(paginator.page_range) # 页码的列表 range(1, 14) page1 = paginator.page(1) # 第一页的page对象
# 显示某一页具体数据的两种方式:
# 方式一:
print("object_list", page1.object_list) # object_list <QuerySet [<Book: Book object (1)>, <Book: Book object (2)>,...
# 方式二:
for i in page1:
print(i)
"""输出
Book object (1)
Book object (2)
Book object (3)
Book object (4)
Book object (5)
Book object (6)
Book object (7)
Book object (8)
""" page2 = paginator.page(2)
print(page2.has_next()) # 是否有下一页
print(page2.next_page_number()) # 下一页的页码
print(page2.has_previous()) # 是否有上一页
print(page2.previous_page_number()) # 上一页的页码 current_page_num = int(request.GET.get("page", 1)) if paginator.num_pages > 11:
if current_page_num-5 < 1:
# 当前页码-5小于1时,默认显示前11个页码
page_range = range(1, 12)
elif current_page_num + 5 > paginator.num_pages:
# 当前页码+5大于总页数时,默认显示后11个
page_range = range(paginator.num_pages-10, paginator.num_pages+1)
else:
# 显示当前页码和左五右五共11个页码
page_range = range(current_page_num-5, current_page_num+6)
else:
# 不超过11个页码的情况,显示所有页码
page_range = paginator.page_range # 超出页码范围或小于1的页码,会抛出emptypage错误,做如下处理:
try:
current_page_num = int(request.GET.get("page", 1)) # /?page=1 get取不到默认给它默认值:1
current_page = paginator.page(current_page_num) print("object_list", current_page.object_list)
for i in current_page:
print(i)
except EmptyPage as e:
current_page = paginator.page(1) # 固定在出现emptypage时显示首页 return render(request, "index.html", locals())
注意:
1、批量生成数据,添加到数组中,再一次性写入数据库表中:Book.objects.bulk_create(book_list)
2、分页器对象生成后,.count查看数据总条数,.num_pages显示总页数,.page_range页码列表。
3、显示某一页的具体数据有两种方式:
# 方式一:
print("object_list", page1.object_list) # object_list <QuerySet [<Book: Book object (1)>, <Book: Book object (2)>,...
# 方式二:
for i in page1:
print(i)
"""输出
Book object (1)
Book object (2)
Book object (3)
Book object (4)
Book object (5)
Book object (6)
Book object (7)
Book object (8)
"""
4、.page()方法可以生成页对象,具备如下方法可用于上一页下一页网页查看。
page2 = paginator.page(2)
print(page2.has_next()) # 是否有下一页
print(page2.next_page_number()) # 下一页的页码
print(page2.has_previous()) # 是否有上一页
print(page2.previous_page_number()) # 上一页的页码
5、得到当前页码,且设置默认页码为1;根据当前页码得到当前页对象。
current_page_num = int(request.GET.get("page", 1)) # /?page=1 get取不到默认给它默认值:1
current_page = paginator.page(current_page_num)
6、针对超出页码范围的页码,会抛出emptypage错误,可以做如下处理:
# 超出页码范围或小于1的页码,会抛出emptypage错误,做如下处理:
try:
current_page_num = int(request.GET.get("page", 1)) # /?page=1 get取不到默认给它默认值:1
current_page = paginator.page(current_page_num) print("object_list", current_page.object_list)
for i in current_page:
print(i)
except EmptyPage as e:
current_page = paginator.page(1) # 固定在出现emptypage时显示首页
7、页面具备翻页功能,设置同时最多只能显示11条,处理如下:
current_page_num = int(request.GET.get("page", 1))
if paginator.num_pages > 11:
if current_page_num-5 < 1:
# 当前页码-5小于1时,默认显示前11个页码
page_range = range(1, 12)
elif current_page_num + 5 > paginator.num_pages:
# 当前页码+5大于总页数时,默认显示后11个
page_range = range(paginator.num_pages-10, paginator.num_pages+1)
else:
# 显示当前页码和左五右五共11个页码
page_range = range(current_page_num-5, current_page_num+6)
else:
# 不超过11个页码的情况,显示所有页码
page_range = paginator.page_range
二、模板层
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.css">
</head>
<body>
<ul>
{% for book in current_page %}
<li>{{ book.title }}:{{ book.price }}</li>
{% endfor %}
</ul>
<nav aria-label="Page navigation">
<ul class="pagination">
{# <li>#}
{# 方法一:上一页在当前页码减1 #}
{# <a href="?page={{ current_page_num|add:-1 }}" aria-label="Previous">#}
{# <span aria-hidden="true">上一页</span>#}
{# </a>#}
{# </li>#}
{# 方法二:#}
{% if current_page.has_previous %}
<li><a href="?page={{ current_page_num.previous_page_number }}" aria-label="Previous"><span aria-hidden="true">上一页</span></a></li>
{% else %}
{# 页码到第一页后,上一页设置为禁用 #}
<li class="disabled"><a href="?page={{ current_page_num.previous_page_number }}" aria-label="Previous"><span aria-hidden="true">上一页</span></a></li>
{% endif %} {# 自动生成<li>标签,路径前面不变得情况下从?开始配置即可 #}
{% for item in page_range %}
{# 当前页面添加active显示高亮 #}
{% if current_page_num == item %}
<li class="active"><a href="?page={{ item }}">{{ item }}</a></li>
{% else %}
<li><a href="?page={{ item }}">{{ item }}</a></li>
{% endif %}
{% endfor %} {% if current_page.has_next %}
<li><a href="?page={{ current_page_num.next_page_number }}" aria-label="Next"><span aria-hidden="true">下一页</span></a></li>
{% else %}
<li class="disabled"><a href="?page={{ current_page_num.next_page_number }}" aria-label="Next"><span aria-hidden="true">下一页</span></a></li>
{% endif %}
</ul>
</nav> </body>
</html>
注意:
1、读取当前页码数据生成标签展示在页面上:
<ul>
{% for book in current_page %}
<li>{{ book.title }}:{{ book.price }}</li>
{% endfor %}
</ul>
2、引入bootstrap
<head>
<link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.css">
</head> body部分:
<nav aria-label="Page navigation">
<ul class="pagination">
...
</ul>
</nav>
3、生成页面页码标签,路径前面不变的情况下可以从?开始配置:
{# 自动生成<li>标签,路径前面不变得情况下从?开始配置即可 #}
{% for item in page_range %}
{# 当前页面添加active显示高亮 #}
{% if current_page_num == item %}
<li class="active"><a href="?page={{ item }}">{{ item }}</a></li>
{% else %}
<li><a href="?page={{ item }}">{{ item }}</a></li>
{% endif %}
{% endfor %}
4、生成页面翻页,上一页、下一页:
(1)第一种方式是在当前页码做加减法:{{ current_page_num|add:-1 }};{{ current_page_num|add:1 }}
<li>
<!--方法一:上一页在当前页码减1 -->
<a href="?page={{ current_page_num|add:-1 }}" aria-label="Previous">
<span aria-hidden="true">上一页</span>
</a>
</li>
(2)第二种方式是使用page对象自带的方法:
<!--上一页-->
{% if current_page.has_previous %}
<li><a href="?page={{ current_page_num.previous_page_number }}" aria-label="Previous"><span aria-hidden="true">上一页</span></a></li>
{% else %}
{# 页码到第一页后,上一页设置为禁用 #}
<li class="disabled"><a href="?page={{ current_page_num.previous_page_number }}" aria-label="Previous"><span aria-hidden="true">上一页</span></a></li>
{% endif %} <!--下一页-->
{% if current_page.has_next %}
<li><a href="?page={{ current_page_num.next_page_number }}" aria-label="Next"><span aria-hidden="true">下一页</span></a></li>
{% else %}
<li class="disabled"><a href="?page={{ current_page_num.next_page_number }}" aria-label="Next"><span aria-hidden="true">下一页</span></a></li>
{% endif %}
Django组件——分页器(paginator)的更多相关文章
- Django - 文件上传、Django组件 - 分页器(paginator)
一.文件上传准备知识 - Content-Type 1.请求头 - Content-Type Content-Type指的是请求体的编码类型,常见的类型共有3种: 1)application/x-ww ...
- Django组件-分页器
Django的分页器(paginator) view from django.shortcuts import render,HttpResponse # Create your views here ...
- Django 组件-分页器
Django的分页器(paginator) view from django.shortcuts import render,HttpResponse # Create your views here ...
- 11 Django组件-分页器
Django的分页器(paginator) view from django.shortcuts import render,HttpResponse # Create your views here ...
- Django的分页器 paginator
导入 from django.core.paginator import Paginator,EmptyPage,PageNotAnInteger Page对象 Paginator.page()将返回 ...
- Django组件——分页器和中间件
分页器 Django内置分页器(paginator) 分页器函数为paginator,里面有几个重要的参数需要我们了解 paginator = Paginator(book_list, 10) #第二 ...
- Django组件--分页器(有用)
一.分页器对象 from django.core.paginator import Paginator,EmptyPage book_list = Book.objects.all() #假设有100 ...
- python 全栈开发,Day79(Django的用户认证组件,分页器)
一.Django的用户认证组件 用户认证 auth模块 在进行用户登陆验证的时候,如果是自己写代码,就必须要先查询数据库,看用户输入的用户名是否存在于数据库中: 如果用户存在于数据库中,然后再验证用户 ...
- Django组件(一) Django之分页器
Django的分页器(paginator)简介 在页面显示分页数据,需要用到Django分页器组件 from django.core.paginator import Paginator Pagina ...
随机推荐
- vmware vSphere虚拟网络(一)
为了更好的了解vSphere网络虚拟化解决方案,这里引入了一些概念,以便我们更好的了解虚拟网络. 一.网卡: 物理网卡称为vmnic,在ESXi中,第一块物理网卡叫做vmnic0,第二块叫做vmnic ...
- 190308python-MySQL
一.Python连接MySQL import pymysql conn = pymysql.connect(host='192.168.100.4', port=3306, user='dongfei ...
- ssh 操作
1.登录 ssh 用户名@远程地址 2.拷贝:scp -r 本地文件夹 远程文件夹(user@ip:目录) 3.从ssh中临时退出: a. ~ (control+z) b.查看后台任务:jobs c ...
- 洛谷 P4001 [ICPC-Beijing 2006]狼抓兔子
题目描述 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...
- 文件管理NSFileManager
//NSFileManager - (void)viewDidLoad { [super viewDidLoad]; NSLog(@"%@",NSHomeDirectory()); ...
- JAVA Web从前端到后台常用框架介绍
原博客:https://blog.csdn.net/u013142781/article/details/50922010 一.SpringMVC http://blog.csdn.net/evank ...
- Python之freshman07 面向对象编程jinjie
本节内容: 面向对象高级语法部分 经典类vs新式类 静态方法.类方法.属性方法 类的特殊方法 反射 异常处理 Socket开发基础 作业:开发一个支持多用户在线的FTP程 经典类vs新式类 把下面代码 ...
- Spring 操作 jdbc 链接数据库
1. 新建资源文件 db.properities jdbc.user=root jdbc.password=root jdbc.driverClass=com.mysql.jdbc.Driver jd ...
- python爬虫之User-Agent用户信息
python爬虫之User-Agent用户信息 爬虫是自动的爬取网站信息,实质上我们也只是一段代码,并不是真正的浏览器用户,加上User-Agent(用户代理,简称UA)信息,只是让我们伪装成一个浏览 ...
- B/S和C/S架构简单理解
B/S和C/S架构简单理解 B/S结构.C/S结构 B(browser浏览器)-S(server服务器),说简单点就是通过浏览器来请求服务器,实现数据交互.那自然了,C(client客户端软件)-S( ...