• 第九章 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'  :按谁排序
    '''
  • 相关阅读:
    python设计模式-单例模式
    bash脚本条件测试总结
    Python网络编程:IO多路复用
    Python面向对象高级编程:@property--把方法变为属性
    Sql Server存储过程基本语法
    接口幂等性
    [转载]使用消息队列实现分布式事务-公认较为理想的分布式事务解决方案
    C#分布式事务解决方案-TransactionScope
    SOA架构和微服务架构的区别
    Atlas实现数据库读写分离
  • 原文地址:https://www.cnblogs.com/neymargoal/p/9839559.html
Copyright © 2020-2023  润新知