drf框架中分页组件
分页组件的使用步骤
1、重写分页类 - 自定义同名类继承drf的分页类,完成必要的配置
2、将重写的分页类配置给有需求的视图类
基础分页器(最常用)
自定义分页类
pagination.py
from rest_framework.pagination import PageNumberPagination as DrfPageNumberPagination class PageNumberPagination(DrfPageNumberPagination): # 默认一页显示的条数 page_size = 2 # url中携带页码的key page_query_param = 'page' # url中用户携带自定义一页条数的key page_size_query_param = 'page_size' # 用户最大可自定义一页的条数 max_page_size = 3 # 默认条数访问 /我们路由设置访问这个视图的路由/?page=页面号 # eg:/我们路由设置访问这个视图的路由/?page=1 # 自定义条数访问 /我们路由设置访问这个视图的路由/?page=页面号&page_size=一页的条数 # eg:/我们路由设置访问这个视图的路由/?page=1&page_size=5
view.py
from . import pagination class 模型名称(ModelViewSet): ....... pagination_class = pagination.PageNumberPagination
偏移分页器
自定制分页类
pagination.py
from rest_framework.pagination import LimitOffsetPagination as DrfLimitOffsetPagination # 偏移分页 class CarLimitOffsetPagination(LimitOffsetPagination): # 默认一页显示的条数 default_limit = 3 # limit控制一页显示的条数,offset控制偏移的条数(从头开始计数) # limit是url中用户携带自定义一页条数的key limit_query_param = 'limit' # offset是url中用户携带自定义偏移条数的key offset_query_param = 'offset' # 限制limit可以设置的最大显示条数 max_limit = 5 # 接口 /我们路由设置访问这个视图的路由/?limit=一页的条数&offset=偏移的条数 # eg:/我们路由设置访问这个视图的路由/?limit=5&offset=2 # 显示3~7条
view.py
from . import pagination class 模型名称(ModelViewSet): ....... # 偏移分页器,没有固定页码,自定义从偏移量开始往后查询自定义条数 pagination_class = pagination.LimitOffsetPagination
游标分页器(加密分页器)
自定制分页类
pagination.py
from rest_framework.pagination import CursorPagination as DrfCursorPagination class CursorPagination(DrfCursorPagination): # 默认一页显示的条数 page_size = 2 # url中携带页码的key(编码后的结果) cursor_query_param = 'cursor' # url中用户携带自定义一页条数的key page_size_query_param = 'page_size' # 用户最大可自定义一页的条数 max_page_size = 3 # 游标分页器的特殊点: """ 1)如果视图类没有配 排序过滤组件filter_backends = [OrderingFilter],采用 ordering 设置的作为默认排序规则 2)如果视图类配了 排序过滤组件filter_backends = [OrderingFilter],url请求必须带上ordering排序规则,因为默认排序规则失效 注:因为游标分页是基于排序后结果上的分页 """ ordering = '-price' # 采用默认排序访问 /我们路由设置访问这个视图的路由/?cursor=加密串 # eg:/我们路由设置访问这个视图的路由/?cursor=cD0z # 结合视图类实现OrderingFilter自定义排序规则 # /我们路由设置访问这个视图的路由/?cursor=加密串&ordering=排序字段 # eg:/我们路由设置访问这个视图的路由/?cursor=cD0z&ordering=-price
view.py
from . import pagination class 模型名称(ModelViewSet): ....... pagination_class = pagination.CursorPagination # 允许排序的字段 ordering_fields = ['id', 'price']