博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
rest-framework 分页器
阅读量:5049 次
发布时间:2019-06-12

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

一 简单分页(查看第n页,每页显示n条)

from rest_framework.pagination import PageNumberPagination# 一 基本使用:url=url=http://127.0.0.1:8000/pager/?page=2&size=3,size无效class  Pager(APIView):    def get(self,request,*args,**kwargs):        # 获取所有数据        ret=models.Book.objects.all()        # 创建分页对象        page=PageNumberPagination()        # 在数据库中获取分页的数据/paginate_queryset本身就有的方法,直接调用        page_list=page.paginate_queryset(ret,request,view=self)        # 对分页进行序列化        ser=BookSerializer1(instance=page_list,many=True)        return Response(ser.data)# 二 自定制 url=http://127.0.0.1:8000/pager/?page=2&size=3# size=30,无效,最多5条class Mypage(PageNumberPagination):    #每页显示多少条    page_size = 2    #查询指定查询那一页的key值    page_query_param = 'page'    # 定制传参/前端控制每页显示多少条的查询key值比如size=9,表示一页显示9条    page_size_query_param = 'size'    # 最大一页的数据/控制每页最大显示多少,size如果传100,最多也是显示10    max_page_size = 5class  Pager(APIView):    def get(self,request,*args,**kwargs):        # 获取所有数据        ret=models.Book.objects.all()        # 创建分页对象        page=Mypage()        # 在数据库中获取分页的数据        page_list=page.paginate_queryset(ret,request,view=self)        # 对分页进行序列化        ser=BookSerializer1(instance=page_list,many=True)        # return Response(ser.data)        # 这个也是返回Response对象,但是比基本的多了上一页,下一页,和总数据条数(了解即可)        return page.get_paginated_response(ser.data)

 settings

REST_FRAMEWORK = {    # 每页显示两条    'PAGE_SIZE':2}

二 偏移分页(在第n个位置,向后查看n条数据

# http://127.0.0.1:8000/pager/?offset=4&limit=3from rest_framework.pagination import LimitOffsetPagination# 也可以自定制,同简单分页class  Pager(APIView):    def get(self,request,*args,**kwargs):        # 获取所有数据        ret=models.Book.objects.all()        # 创建分页对象        page=LimitOffsetPagination()        # 在数据库中获取分页的数据        page_list=page.paginate_queryset(ret,request,view=self)        # 对分页进行序列化        ser=BookSerializer1(instance=page_list,many=True)        # return page.get_paginated_response(ser.data)        return Response(ser.data) 二 自定制 url=http://127.0.0.1:8000/pager/?page=2&size=3# size=30,无效,最多5条class Mypage( LimitOffsetPagination):    #从标杆位置往后取几个,默认取2个,我可以指定    default_limit = 2    # 每次取得条数    limit_query_param = 'limit'    # #标杆值,现在偏移到哪个位置,如果offset=6 表示当前在第6条位置上,往后取    offset_query_param = 'offset'    # 最大一页的数据    max_limit = 5class  Pager(APIView):    def get(self,request,*args,**kwargs):        # 获取所有数据        ret=models.Book.objects.all()        # 创建分页对象        page=Mypage()        # 在数据库中获取分页的数据        page_list=page.paginate_queryset(ret,request,view=self)        # 对分页进行序列化        ser=BookSerializer1(instance=page_list,many=True)        # return Response(ser.data)        # 这个也是返回Response对象,但是比基本的多了上一页,下一页,和总数据条数(了解即可)        return page.get_paginated_response(ser.data)

三 CursorPagination(加密分页,只能看上一页和下一页,速度快)

 

from rest_framework.pagination import CursorPagination# 看源码,是通过sql查询,大于id和小于idclass  Pager(APIView):    def get(self,request,*args,**kwargs):        # 获取所有数据        ret=models.Book.objects.all()        # 创建分页对象        page=CursorPagination()        #按什么排序        page.ordering='nid'        # 在数据库中获取分页的数据        page_list=page.paginate_queryset(ret,request,view=self)        # 对分页进行序列化        ser=BookSerializer1(instance=page_list,many=True)        # 可以避免页码被猜到        return page.get_paginated_response(ser.data)#如果要自定义要先继承CursorPagination,然后重写三个参数        # 每页显示的大小        page.page_size = 3        # 查询的key值        page.cursor_query_param = 'cursor'        # 按什么排序        page.ordering = 'id'

 

转载于:https://www.cnblogs.com/HUIWANG/p/11138878.html

你可能感兴趣的文章
socket
查看>>
Vue中使用key的作用
查看>>
二叉索引树 树状数组
查看>>
日志框架--(一)基础篇
查看>>
Java设计模式之原型模式
查看>>
Spring学习(四)-----Spring Bean引用同xml和不同xml bean的例子
查看>>
哲理故事与管理之道(20)-用危机激励下属
查看>>
关于源程序到可运行程序的过程
查看>>
wepy的使用
查看>>
转载:mysql数据库密码忘记找回方法
查看>>
scratch少儿编程第一季——06、人在江湖混,没有背景怎么行。
查看>>
面向对象1
查看>>
在ns2.35中添加myevalvid框架
查看>>
【贪心+DFS】D. Field expansion
查看>>
为什么要使用href=”javascript:void(0);”
查看>>
二进制文件的查看和编辑
查看>>
C# Async与Await的使用
查看>>
Mysql性能调优
查看>>
iOS基础-UIKit框架-多控制器管理-实例:qq界面框架
查看>>
javascript学习---BOM
查看>>