Django REST Framework之分页器
Django REST Framework提供了三种分页器:
- PageNumberPagination。基于Django Paginator封装,使得操作更方便,只需要做一些配置即可。分页方式:根据页数和每页的大小进行分页。
- LimitOffsetPagination。分页方式:从第几条开始找,向后找多少条。
- CursorPagination。实现比较复杂,有自己的特点。
说明:一般在分页前,需要先将数据排序。如果不排序,会报警告
PageNumberPagination
utils/pagination.py
from rest_framework.pagination import PageNumberPagination
class MyPagination(PageNumberPagination):
# 只需要做一些配置即可
page_size = 1 # 每页的数据量(默认)
page_query_param = "page" # 请求参数中的 page参数名
page_size_query_param = "size" # 请求参数中的 page_size参数名
max_page_size = 3 # 每页最大数量,请求参数中如果超过了这个配置,不会报错,会按照此配置工作
需要说明的是:我们配置的参数名,需要使用get请求。DRF在实现过程中只是针对get获取参数,如果需要其他方式传递参数(如post),需要自己修改源码。
views.py
from utils.pagination import MyPagination
class BookView(APIView):
def get(self, request):
book_list = Book.objects.all().order_by("id")
# 实例化分页器对象
pageObj = MyPagination() # PageNumberPagination
# 调用分页方法
page_query = pageObj.paginate_queryset(book_list, request, view=self)
# 序列化器 many表示取出多条数据
ret = BookSeriallzer(page_query, myFields="__all__", many=True)
print(ret)
resIO = pageObj.get_paginated_response(ret.data) # 获取分页的结果,将分页后的结果数据与Response封装在一起
# 将数据分为count,next,prev,result。分别是数据总量,上一页/下一页的请求地址,本页的数据
return resIO
LimitOffsetPagination
utils.pagination.py
class LimitPagination(LimitOffsetPagination):
'''需要我们规定:从第几条开始找,向后找多少条limit'''
default_limit = 1 # 向后找几条的默认配置
limit_query_param = "limit" # 请求参数中的limit参数名
offset_query_param = "offset" # 请求参数中的offset参数名
max_limit = 3 # 最大的寻找条数
说明:参数的请求方法同上,get获取。
views.py
from utils.pagination import LimitPagination
class BookView(APIView):
def get(self, request):
book_list = Book.objects.all().order_by("id")
# 实例化分页器对象
pageObj = LimitPagination() # LimitOffsetPagination
# 调用分页方法
page_query = pageObj.paginate_queryset(book_list, request, view=self)
# 序列化器 many表示取出多条数据
ret = BookSeriallzer(page_query, myFields="__all__", many=True)
print(ret)
resIO = pageObj.get_paginated_response(ret.data) # 获取分页的结果,将分页后的结果数据与Response封装在一起
# 将数据分为count,next,prev,result。分别是数据总量,上一页/下一页的请求地址,本页的数据
return resIO
CursorPagination
游标分页。有时候,别人能够根据你的请求参数推断出你的数据库中有多少条数据,有些公司觉得这不够安全。使用次分页方式可以将游标进行加密,使人无法获知数据的数目。
特点:
- 分页前必须要排序
- 游标加密,不允许导航到任意位置(基于前两种的分页可以通过传参,对任意的页数发起请求,游标分页不允许),只能"next"和“prev”
- 支持非常大的数据集。如果表中有非常大的数据量,基于偏移的分页器效率变得很低,但基于游标分页的效率高。
utils/pagination.py
class CurPagination(CursorPagination):
'''游标分页'''
cursor_query_param = "cursor" # 游标请求参数,相当于page页数,但该数据是加密的,来自于上次分页返回
page_size = 2 # 默认每页显示的
ordering = "-id" # 排序 根据id倒序
max_page_size = 10 # 每页显示的最大条数
views.py
同上☝

浙公网安备 33010602011771号