首页
学习
活动
专区
圈层
工具
发布

Django分页器

一.分页器 分页功能是所有网页上都需要提供的功能,当要展示的条目比较多时,就需要进行分页,不但能减小数据库读取数据压力,也有利于用户浏览。...Django为我们提供了一个Paginator分页工具,这个类帮助我们来管理分页数据,该类存放在django/core/paginator.py它可以接收列表、元组或其他可迭代对象。...实例: from django.core.paginator import Paginator lis = ['yven','lqz','egon','hwt','lyf'] # 对lis进行分页,每页...print(page2.previous_page_number()) 所以,使用Paginator分四步: 使用任何方法,获取要展示的对象列表QuerySet; 将列表和每页个数传递给Paginator,返回一个分页对象...page_range:基于1的页数范围迭代器 方法: Paginaor.page(number):返回指定页面的对象列表 四.异常处理 在实例使用中,用户请求的页面,可能千奇百怪,这就会有可能导致异常

87630
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    django分页器的用法_django分页查询

    前言 当后台返回的数据过多时,我们就要配置分页器,比如一页最多只能展示10条等等,drf中默认配置了3个分页面 PageNumberPagination:基础分页器,性能略差 LimitOffsetPagination...:偏移分页器 CursorPagination:游标分页器,性能强大 PageNumberPagination 基础分页器PageNumberPagination,数据量越大性能越差。...""" # 默认页面展示的条数 page_size = 3 # 前端访问url需要添加 ?...page=2&page_size=5,代表访问第二页的数据,用户自定义返回的条数为5条 LimitOffsetPagination 首先我们自定义一个分页器类,继承自LimitOffsetPagination...,只是游标分页的针对下一页数据的url进行了加密 首先我们自定义一个分页器类,继承自CursorPagination: class MyCursorPagination(CursorPagination

    1.4K20

    Django分页器的用法

    1、准备基础数据 2、一次性展示数据 3、引入分页器 Django是一个大而全的框架。...需要明确的是,传参进行分页获取分页后的数据,一般都是通过向服务器发送get请求的方式实现的,在向后端服务发送查看数据的同时可以携带一个或多个参数并发送get请求来实现分页查看功能 前面总结过drf框架中分页器的使用...,本文主要介绍在利用Django开发MVT模型项目时分页器的使用 1、准备基础数据 设计表模型 为了体现分页的效果,需要先创建一个表并准备较多数据,模型如下 from django.db import...引入分页器后,可以对全局分页对象和单页对象进行相关操作,相关语法 # 引入分页器 from django.core.paginator import Paginator...,例如每页取出8条,获取用户给出的页码条件数,返回相应页的数据,默认不给出任何条件时返回第一页的数据 from django.core.paginator import Paginator # 取出当前用户页码

    1.2K10

    Django 使用Paginator分页器

    ,当我们的页码数量过多时,会全部展示出来,整个页面都是很不美观,我们直接在上方代码上稍加修改一下试试. # name: views.py from django.shortcuts import render...: 通过使用bootstrap框架,并配合Django自带的分页组件即可实现简单的分页效果. # name: models.py from django.db import models class...,当我们页面中的页码数量过多时,默认会将页码全部展示出来,整个页面看上去很不美观,我们可以直接在上方分页代码上稍加修改即可,如下代码. # name: views.py from django.shortcuts...item.hostname, 'hostaddr':item.hostaddr, 'hostmode':item.hostmode } data_list.append(dict) # 使用分页器分页...context = pageInator.page(pageIndex) for item in context: ref_data.append(item) # 返回分页格式

    1.3K30

    Django自定义实现分页器

    1、分析和推导 1.1 当前页 1.2 起始位置和终止位置 1.3 添加按钮传递页码数 2、方法的封装 2.1 分页器类 2.2 视图函数 2.3 模板页面 前面的文章中分别介绍了drf框架中分页器的使用及...Django框架中分页器的用法,其重点在于视图函数和模板页面如何利用自带的分页器的相关参数进行数据传递和页面渲染 本文继续介绍分页器,即自定义分页器如何实现,其实也就是如何使用自定义的方式计算出和上面类似自带的分页器的相关参数值...1、分析和推导 分页中的关键信息:当前页、每页展示多少条、起始位置、终止位置 1.1 当前页 思路:浏览器携带页码发送get请求,获取当前页信息。...2、方法的封装 上面是自定义分页器开发流程的基本推导思路,最后将自定义分页器进行封装 2.1 分页器类 mypage.py class Pagination(object): def __init...book in page_queryset %} { book.title } {% endfor %} {#利用自定义分页器直接显示分页器样式

    1.1K20

    Python 开发web服务器,返回HTML页面

    仅供学习,转载请注明出处 前情篇章 Python 开发Web静态服务器 - 返回固定值:胖子老板,来包槟榔 从上一个篇章的内容中已经完成了使用TCP协议返回HTTP的请求,达到一个返回数据到访问浏览器的效果...那么本次篇章的需求: 就是返回一个HTML文件到浏览器。 那么该怎么去开发这个功能呢? 大致开发思路 上一篇是通过TCP返回一长串http的数据,分别为 header 和 body 部分。...准备一个index.html的代码,提供返回浏览器访问 可以到一些建站模板网站下载一份前端代码: ? 那么下一步将html文件上传到服务器上。 ?...可以看到浏览器已经显示index.html的内容了,同时还发送了很多的请求到服务端。 但是由于没有请求下载到css和图片等数据内容,所以直接看到一个比较简陋的页面。...那么下一步,就应该使用正则匹配出所有的文件路径,这样的话,就可以返回浏览器关于css、js、image的图片了。

    4.1K50

    Python 开发web服务器,返回HTML页面

    前言 从上一个篇章的内容中已经完成了使用TCP协议返回HTTP的请求,达到一个返回数据到访问浏览器的效果。 那么本次篇章的需求: 就是返回一个HTML文件到浏览器。 那么该怎么去开发这个功能呢?...\r\n" # 合并返回的response数据 response = response_headers + response_body # 返回数据给浏览器...但是由于没有请求下载到css和图片等数据内容,所以直接看到一个比较简陋的页面。那么下一步,就应该使用正则匹配出所有的文件路径,这样的话,就可以返回浏览器关于css、js、image的图片了。...运行如下: 好了,到了这里就可以先简单的打开对应的文件,返回浏览器即可。 运行如下: 好啦,写到这里基本上也完成的七七八八啦。剩下就是优化以及bug的调整。那么到底存在有哪些BUG呢?...(response_body) #转码utf-8并send数据到浏览器 except: # 如果没有找到文件,那么就打印404 not found # 设置返回的头信息

    1.3K10

    面试题:浏览器中输入URL返回页面过程?

    面试题:浏览器中输入URL返回页面过程?...如果本地 DNS 缓存中没有记录,则进行迭代式的 DNS 查询流程,从根域名服务器一直查找到目标网站的权威 DNS 服务器获取 IP 地址。...发送 HTTP 请求:由客户端(即浏览器)向目标服务器发送HTTP请求,请求资源文件、页面数据或提交表单等信息。HTTP请求报文主要由请求行、请求头部和请求体组成。...解析渲染页面:客户端使用 HTML 页面代码、CSS 样式表和 JavaScript 程序,按照 W3C 的标准对页面进行解析处理和渲染,生成用户可视化的网页。...浏览器输入 URL 返回页面过程涉及到多个协议和技术,如 DNS 解析、HTTP(S) 协议、TCP/IP 协议等,在每一步都需要保证高效、可靠和安全的数据传输。

    20410

    DartVM服务器开发(第三天)--pub管理器、返回html页面

    上一篇:DartVM服务器开发(第二天)--处理请求 上一篇文章中主要介绍了如何处理请求,获取请求方法,获取请求参数,获取请求头,今天我们学习一下添加pub包管理器、规划项目结构、使用第三方库、返回...现在我们可以使用http_server这个包了 4.返回html页面 在返回html页面之前,我们需要准备一个html页面吧,在项目根目录下新建一个文件夹,以webApp为命名,说明这个是前端页面,然后新建一个...html文件目录.png 那么,我们怎样将这个页面绑定到服务器上面呢,在刚才,我们依赖了http_server这个包,我们可以使用这个包去返回这个html页面 main() async { VirtualDirectory...,返回我们的刚刚写好的html页面 //因为http_server这个包已经为我们处理好了,所以如果html不存在,也不会让服务器奔溃掉,而是返回未找到页面 staticFiles.serveFile...规划项目结构,使用第三方库,返回html页面,记录请求日志,那么,大家都对dartVM服务器开发都有一个认识了吧,经验老道的程序员,可能在今天起就会尝试着自己去继续完善DartVM服务器项目,那么,我们明天见吧

    1.1K40
    领券