第九章 restframework——分页器

第九章 restframework——分页器

一、简单分页(常用)

二、偏移分页(不常用)

三、加密分页(效率高,且安全)

一、简单分页(常用)

需求:查看第n页,每页显示n条

urls.py

url(r'^pager/$', views.Pager.as_view()),

Serializers

class BookSerializer1(serializers.ModelSerializer):
    class Meta:
        model=models.Book
        # fields="__all__"
        exclude=('authors',)

导入模块

from rest_framework.pagination import PageNumberPagination

settings.py

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

1.使用默认配置

views.py

from rest_framework.pagination import PageNumberPagination
# 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()
        # 在数据库中获取分页的数据
        page_list=page.paginate_queryset(ret,request,view=self)
        # 对分页进行序列化
        ser=BookSerializer1(instance=page_list,many=True)
        return Response(ser.data)

2.自定义(继承PageNumberPagination类,重写属性)

# url=http://127.0.0.1:8000/pager/?page=2&size=3
# size=30,无效,最多5条
class Mypage(PageNumberPagination):
    page_size = 2
    page_query_param = 'page'
    # 定制传参
    page_size_query_param = 'size'
    # 最大一页的数据
    max_page_size = 5
class  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)
# 1 再setting里配置每页条数
# 2 写一个类,继承它,属性重写
# 3 再对象里修改
'''
        每页显示多少条api_settings.PAGE_SIZE
        page_size =
        查询指定页码的参数
        page_query_param = 'page'
        指定每页显示条数
        page_size_query_param = None
        限制每页显示最大条数
        max_page_size = None
'''

二、偏移分页(不常用)

需求:在第n个位置,向后查看n条数据

# http://127.0.0.1:8000/pager/?offset=4&limit=3
from 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)
# 1 再setting里配置每页条数
# 2 写一个类,继承它,属性重写
# 3 再对象里修改
'''
        default_limit:默认显示多少条
        max_limit:最大显示多少条
        limit_query_param:重新命名limit(limit=4:表明显示四条,受max_limit的限制)
        offset_query_param:指定查询的标杆名(offset=1:表明从第二条开始,往后偏移)
'''

三、加密分页(效率高,且安全)

需求:加密分页,只能看上一页和下一页

from rest_framework.pagination import CursorPagination
# 看源码,是通过sql查询,大于id和小于id
class  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)
# 1 再setting里配置每页条数
# 2 写一个类,继承它,属性重写
# 3 再对象里修改
'''
        cursor_query_param = 'cursor':查询的名字
        page_size = api_settings.PAGE_SIZE:每页显示的条数
        ordering = '-created'  :按谁排序
'''
原文地址:https://www.cnblogs.com/neymargoal/p/9839559.html