drf分页器

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

from rest_framework.pagination import PageNumberPagination

# 一 基本使用:url=url=http://127.0.0.1:8000/books/?page=2&size=3,size无效
class Book(ViewSetMixin,APIView):
    def get_all(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)

# 二 自定制 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'
    # 指定当前页显示多少条
    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)

# 可以不继承来修改对象的值
# page=PageNumberPagination()
# page.page_size=2
# page.page_query_param='bb'

setting里

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

 路由:

url(r'^books/', views.Book.as_view({'get': 'get_all'}))

 Serializers

class BookSerializer1(serializers.ModelSerializer):
    class Meta:
        model=models.Book
        fields="__all__"

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

from rest_framework.pagination import LimitOffsetPagination
class Book(ViewSetMixin, APIView):
    def get_all(self, request):
        response = {'status': 100, 'msg': '查询成功'}
        book_list = models.Book.objects.all()
        page = LimitOffsetPagination()
     #每页显示3条 page.default_limit
=3
     #每页显示的最大的条数 page.max_limit=4 page_list = page.paginate_queryset(book_list, request, self) ser = BookSerializer(page_list, many=True) response['data'] = ser.data return Response(response)

#每页显示的条数
default_limit = api_settings.PAGE_SIZE
#标杆值
  offset_query_param = 'offset'
#往后偏移多少
  limit_query_param = 'limit'
#每页显示最大的条数
  max_limit = None
http://127.0.0.1:8000/books/?offset=2&limit=5  ——以2为标杆,显示5条,但是page.max_limit=4,所以查询出第3,4,5,6共4条数据

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

from rest_framework.pagination import CursorPagination
# 看源码,是通过sql查询,大于id和小于id
class Book(ViewSetMixin, APIView):
    def get_all(self, request):
        response = {'status': 100, 'msg': '查询成功'}
        book_list = models.Book.objects.all()
        page = CursorPagination()
        # 按pk进行排序
        page.ordering = 'pk'
        page_list = page.paginate_queryset(book_list, request, self)
        ser = BookSerializer(page_list, many=True)
        response['data'] = ser.data
        return Response(response)

#按nid排序
   page.ordering = 'nid'
   #查询的key值
   cursor_query_param = 'cursor' 
   #每页显示多少条
   page_size = api_settings.PAGE_SIZE

 

posted @ 2018-12-18 20:24  liweiwei0307  阅读(251)  评论(0编辑  收藏  举报