博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用Django实现分页器功能
阅读量:5026 次
发布时间:2019-06-12

本文共 2995 字,大约阅读时间需要 9 分钟。

要使用Django实现分页器,必须从Django中导入Paginator模块

from django.core.paginator import Paginator

假如现在有150条记录要显示,每页显示10条

>>> from django.core.paginator import Paginator#导入Paginator模块>>> list1=[i for i in range(0,150)]#使用列表生成器生成一个包含150个数字的列表>>> page1=Paginator(list1,10)#生成一个Paginator对象>>> print(page1.count)#打印总的记录数,即列表list1的长度150>>> print(page1.num_pages)#打印总的页数,即总记录数除以每页显示的条目数15>>> print(page1.page_range)#页数的列表range(1, 16)>>> print(page1.page(1))#打印第一页的page对象
>>> page1.page(1).object_list#打印第一页的所有记录[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]>>> page1.page(2).object_list#打印第二页的所有记录[10, 11, 12, 13, 14, 15, 16, 17, 18, 19]>>> page1.page(2).next_page_number()#打印当前的页(第2页)的下一页的页码3>>> page1.page(2).has_next()#第2页是否有下一页True>>> page1.page(2).has_previous()#第2页是否有上一页True>>> page1.page(2).has_other_pages()#第2是否有其他页True>>> page1.page(2).start_index()#第2页第一条记录的序号11>>> page1.page(2).end_index()#第2页最后一条记录的序号20>>> page1.page(0)#第0页是否有记录,会报错Traceback (most recent call last): File "
", line 1, in
... raise EmptyPage(_('That page number is less than 1'))django.core.paginator.EmptyPage:
>>> page1.page(15)#打印第15页的对象

例子,使用Django实现一个分页效果

前端代码:

{% load staticfiles %}    
Title

分页器

    #遍历boot_list中的所有元素 {% for book in book_list %} #打印书籍的名称和价格
  • {
    { book.title }} {
    { book.price }}
  • {% endfor %}
    {#上一页按钮开始#} {# 如果当前页有上一页#} {% if book_list.has_previous %} {# 当前页的上一页按钮正常使用#}
    {% else %} {# 当前页的不存在上一页时,上一页的按钮不可用#}
    {% endif %} {#上一页按钮结束#} {# 页码开始#} {% for num in paginator.page_range %} {% if num == currentPage %}
  • {
    { num }}
  • {% else %}
  • {
    { num }}
  • {% endif %} {% endfor %} {#页码结束#} {# 下一页按钮开始#} {% if book_list.has_next %}
    {% else %}
    {% endif %} {# 下一页按钮结束#}

后端代码:

#导入render和HttpResponse模块from django.shortcuts import render,HttpResponse#导入Paginator,EmptyPage和PageNotAnInteger模块from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger#从Django项目的应用中导入模块from app01.models import *def index(request):    #获取Book数据表中的所有记录    book_list=Book.objects.all()    #生成paginator对象,定义每页显示10条记录    paginator = Paginator(book_list, 10)    #从前端获取当前的页码数,默认为1    page = request.GET.get('page',1)        #把当前的页码数转换成整数类型    currentPage=int(page)    try:        print(page)        book_list = paginator.page(page)#获取当前页码的记录    except PageNotAnInteger:        book_list = paginator.page(1)#如果用户输入的页码不是整数时,显示第1页的内容    except EmptyPage:        book_list = paginator.page(paginator.num_pages)#如果用户输入的页数不在系统的页码列表中时,显示最后一页的内容    return render(request,"index.html",locals())

转载于:https://www.cnblogs.com/renpingsheng/p/7461193.html

你可能感兴趣的文章
Oracle数据库的增、删、改、查
查看>>
MySql执行分析
查看>>
git使用中的问题
查看>>
yaml文件 .yml
查看>>
linux字符集修改
查看>>
phpcms 添加自定义表单 留言
查看>>
mysql 优化
查看>>
读书笔记 ~ Nmap渗透测试指南
查看>>
WCF 配置文件
查看>>
动态调用WCF服务
查看>>
oracle导出/导入 expdp/impdp
查看>>
类指针
查看>>
css修改滚动条样式
查看>>
2018.11.15 Nginx服务器的使用
查看>>
Kinect人机交互开发实践
查看>>
百度编辑器UEditor ASP.NET示例Demo 分类: ASP.NET...
查看>>
JAVA 技术类分享(二)
查看>>
android客户端向服务器发送请求中文乱码的问
查看>>
Symfony翻译教程已开课
查看>>
TensorFlow2.0矩阵与向量的加减乘
查看>>