一、分页

Django的分页器(paginator)

view.py

from django.shortcuts import render,HttpResponse

# Create your views here.

from app09 import models

# 导入分页模块
from django.core.paginator import Paginator
# 做分页
# 分页器的对象,需要传object_list(要分页的所有数据queryset对象), per_page(每页要显示的个数), def paginator(request):
book_l = models.Book.objects.all().order_by('pk')
paginator = Paginator(book_l, 40) try:
#只写page,默认是none,我们默认是第一页。
currentpage = int(request.GET.get('page',1))
# page传个页码数,比如传1,就是每一页的对象,paginator相当于一本书,paginator.page就相当于书的具体的哪一页 # 取出书的第一页,第一页的对象,page是每一页的对象
# page = paginator.page(1) page = paginator.page(currentpage)
except Exception as e:
#如果输入法的不合法就显示第一页,就不会报错
currentpage = 1
page = paginator.page(currentpage) #传入页码数,拿到的就是当前页对象
page = paginator.page(currentpage) # page_range = paginator.page_range #1 总页数是否大于11,当总页码数大于11时
if paginator.num_pages >11:
#1.1 当前页码数是否小于6
if currentpage <=6:
#1.1.1 当前页码数小于6的时候,就生成11个页码数
page_range = range(1,12)
#1.2 当前页码数+5大于总页码数
elif currentpage + 5 >= paginator.num_pages:
# 1.2.1 往后推11页页码数
page_range = range(paginator.num_pages - 10,paginator.num_pages + 1)
# 1.3 当前页码数大于6,就生成一个左5 右5的区间
else:
page_range = range(currentpage - 5,currentpage + 6)
#2 总页码数不大于11的是有,页码有多少显示多少页码
else:
page_range = paginator.page_range # 总数据条数
print('总数据条数', paginator.count)
print('总页数', paginator.num_pages) # 需要在前端显示出来
print('页码的列表', paginator.page_range)
print('页码的列表', list(paginator.page_range)) # page传个页码数,比如传1,就是每一页的对象,paginator相当于一本书,paginator.page就相当于书的具体的哪一页 # 取出书的第一页,第一页的对象,page是每一页的对象
# page = paginator.page(1) # page = paginator.page(currentpage) # 每次从这一页中拿出一个个的书
# 在模板中for循环这个就可以拿出数据
# for book in page:
# print(book.name)
# print(page.has_next()) #是否有下一页
# print(page.next_page_number()) #是否有下一页的页码
# print(page.has_previous()) #是否有上一页
# print(page.previous_page_number()) #是否有上一页的页码 # 去写模板 return render(request, 'pagintaor.html', locals()) def booklist(request):
book_l = models.Book.objects.all() return HttpResponse('OK') # 批量生产数据
# def createbook(request):
# # 插入104本书(对象),先生成列表
# li = []
# for i in range(105):
# li.append(models.Book(name='honglpimeng%s'%i,price=1+i))
# res = models.Book.objects.bulk_create(li,20)
#
# return HttpResponse('OK') <><><><><><><><><<><><><><><><><><><><><><><><><><><><><><><><><><><><><>< HTML
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
{# 引入bootstrap#}
<link rel="stylesheet" href="/static/bootstrap-3.3.7-dist/css/bootstrap.css">
<title>Title</title>
</head>
<body> <table class="table table-bordered">
<thead>
<tr>
<th>序号</th>
<th>书名</th>
<th>价格</th>
</tr>
</thead>
<tbody>
{% for book in page %}
<tr>
<td>{{ forloop.counter }}</td>
<td>{{ book.name }}</td>
<td>{{ book.price }}</td>
</tr> {% endfor %} </tbody> </table> {#//加分页 让有多少页就显示多少页#}
<nav aria-label="Page navigation">
<ul class="pagination">
{% if page.has_previous %}
<li>
{# <a href="/paginator/?page={{ page.previous_page_number }}" aria-label="Previous">#}
<a href="/paginator/?page={{ page.previous_page_number }}" aria-label="Previous">
<span aria-hidden="true">上一页</span>
</a>
</li>
{% else %}
<li class="disabled">
<a href="" aria-label="Previous">
<span aria-hidden="true">上一页</span>
</a>
</li> {% endif %} {% for foo in page_range %} {% if currentpage == foo %}
{# 变色,判断当前页面是不是循环到的页面,如果是加active#}
<li class="active"><a href="/paginator/?page={{ foo }}">{{ foo }}</a></li> {% else %}
<li><a href="/paginator/?page={{ foo }}">{{ foo }}</a></li> {% endif %} {% endfor %} {% if page.has_next %}
<li>
{# <a href="/paginator/?page={{ page.next_page_number }}" aria-label="Next">#}
<a href="/paginator/?page={{ page.next_page_number }}" aria-label="Next">
<span aria-hidden="true">下一页</span>
</a>
</li>
{% else %}
<li class="disabled">
<a href="" aria-label="Next">
<span aria-hidden="true">下一页</span>
</a>
</li>
{% endif %} </ul>
</nav> </body>
</html>

<><><><><><><><><<><><><><><><><><><><><><><><><><><><><><><><><><><><><><
												

Django的分页和中间件的更多相关文章

  1. Python Django的分页,Form验证,中间件

    本节内容 Django的分页 Form 中间件 1 Django 分页 1.1 Django自带的分页 1.首先来看下我的测试数据环境 ############ models.py ######### ...

  2. Django组件——分页器和中间件

    分页器 Django内置分页器(paginator) 分页器函数为paginator,里面有几个重要的参数需要我们了解 paginator = Paginator(book_list, 10) #第二 ...

  3. Django【第10篇】:Django之分页初级版本

    分页和中间件 一.分页 Django的分页器(paginator) view.py from django.shortcuts import render,HttpResponse # Create ...

  4. 第二十一章 Django的分页与cookie

    第二十一章 Django的分页与cookie 第一课 模板 1.模板的继承 在Template目录下新建模板master.html <!DOCTYPE html> <html lan ...

  5. Django----列表分页(使用Django的分页组件)

    目的:是为了实现列表分页 1.定制URL http://127.0.0.1:8000/blog/get_article?page=3之前定制URL是在url后增加了/id,这次使用参数的方式 def ...

  6. {Django基础九之中间件} 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证

    Django基础九之中间件 本节目录 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证 六 xxx 七 xxx 八 xxx 一 前戏 我们在前面的课程中已经学会了 ...

  7. Django WSGI,MVC,MTV,中间件部分,Form初识

    一.什么是WSGI? WEB框架的本质是一个socket服务端接收用户请求,加工数据返回给客户端(Django),但是Django没有自带socket需要使用 别人的 socket配合Django才能 ...

  8. Django—自定义分页

    分页功能在每个网站都是必要的,对于分页来说,其实就是根据用户的输入计算出应该显示在页面上的数据在数据库表中的起始位置. 确定分页需求: 1. 每页显示的数据条数 2. 每页显示页号链接数 3. 上一页 ...

  9. day 63 Django基础九之中间件

    Django基础九之中间件   本节目录 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证 六 xxx 七 xxx 八 xxx 一 前戏 我们在前面的课程中已经学 ...

随机推荐

  1. 通过JS如何获取IP地址

    通过JS获取你真实的外网IP和内网IP,就算开代理也没有用,想想真是太可怕了,还能不能愉快的装逼了! 代码: //get the IP addresses associated with an acc ...

  2. BZOJ3237:[AHOI2013]连通图(线段树分治,并查集)

    Description Input Output Sample Input 4 5 1 2 2 3 3 4 4 1 2 4 3 1 5 2 2 3 2 1 2 Sample Output Connec ...

  3. 【转】具透 | 你可能不知道,iOS 10 有一个中国「特供」的联网权限功能

    9 月底,苹果正式在北京成立了苹果中国研发中心.近几年,我们也在每年更新的 iOS 系统中不断看到,苹果对中国市场的关照.从早前的九宫格输入法,到最近的骚扰电话拦截,都照顾了国内用户的需求. 在 iO ...

  4. spring boot启动报错

    Exception encountered during context initialization - cancelling refresh attempt: org.springframewor ...

  5. 在 C 代码中嵌入 Python 语句或使用 Python 模块 (Visual Studio 2013 环境设置)

    1) 新建一个 内嵌 Python 语句的 C 代码, // This is a test for check insert the Python statements or module in C. ...

  6. python3 练习题 day04

    '''1.整理装饰器的形成过程,背诵装饰器的固定格式''''''开放封闭原则:为了保证程序的稳定性,和功能的可开放性,在不修改目标函数源代码和调用方式的情况下,对目标函数增加新功能'''# def w ...

  7. Leetcode 1. Two Sum (Python)

    refer to https://blog.csdn.net/linfeng886/article/details/79772348 Description Given an array of int ...

  8. Android 读取后台数据并显示。模拟小区车辆管理系统

    帮别人做的演示系统,只具有基本的增删查改功能. 核心是android端和后台通过http传输数据 后台是asp.net,数据库是ms sql 2008 android端 private void ge ...

  9. Vue-发布订阅机制(bus)实现非父子组件的传值

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. 解决IsEditable="True"的ComboBox在DataGrid中点击一次不能选中行的问题

    原文:解决IsEditable="True"的ComboBox在DataGrid中点击一次不能选中行的问题 此方法很笨拙,并不推荐使用!!! 此方法很笨拙,并不推荐使用!!! 此方 ...