一、分页
REST 框架包括对可自定义分页样式的支持。这允许您修改将大型结果集拆分为各个数据页的方式。
分页 API 可以支持以下任一功能:
作为响应内容的一部分提供的分页链接。
响应标头中包含的分页链接。
内置样式目前都使用作为响应内容的一部分包含的链接。使用可浏览 API 时,此样式更易于访问。
仅当您使用通用视图或视图集时,才会自动执行分页。如果您使用的是常规 ,则需要自己调用分页 API,以确保返回分页响应。有关示例,请参阅 和 类的源代码。
可以通过将分页类设置为 来关闭分页。
1.全局设置分页
REST_FRAMEWORK = { 'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.LimitOffsetPagination', 'PAGE_SIZE': 100 }
请注意,您需要设置分页类和应使用的页面大小。默认情况下,两者都是 。
您还可以使用该属性在单个视图上设置分页类。通常,您需要在整个 API 中使用相同的分页样式,但您可能希望根据每个视图改变分页的各个方面,例如默认或最大页面大小。
二、PageNumberPagination
1.属性说明
若要设置这些属性,应重写该类,然后启用自定义分页类,如上所述。PageNumberPagination
django_paginator_class- 要使用的 Django 分页器类。默认值为
,对于大多数用例来说应该没问题。django.core.paginator.Paginator
page_size- 指示页面大小的数值。如果设置,这将覆盖该设置。默认为与设置键相同的值。PAGE_SIZEPAGE_SIZE
page_query_param- 一个字符串值,指示要用于分页控件的查询参数的名称。
page_size_query_param-
如果设置,这是一个字符串值,指示查询参数的名称,该参数允许客户端基于每个请求设置页面大小。缺省为
,表示客户端可能无法控制请求的页面大小。None
max_page_size-
如果设置,这是一个数值,指示允许的最大请求页面大小。仅当同时设置此属性时,此属性才有效。page_size_query_param
last_page_strings- 字符串值的列表或元组,指示可与
请求集合中最后一页一起使用的值。默认为page_query_param(‘last’,)
template- 在可浏览 API 中呈现分页控件时要使用的模板的名称。可以重写以修改呈现样式,或设置为完全禁用 HTML
分页控件。缺省值为 。None"rest_framework/pagination/numbers.html"
三、LimitOffsetPagination
1.属性说明
若要设置这些属性,应重写该类,然后启用自定义分页类,如上所述。LimitOffsetPagination
default_limit- 一个数值,指示客户端未在查询参数中提供限制时要使用的限制。默认为与设置键相同的值。PAGE_SIZE
limit_query_param- 指示“限制”查询参数名称的字符串值。缺省值为 。‘limit’
offset_query_param- 指示“offset”查询参数名称的字符串值。缺省值为 。‘offset’
max_limit- 如果设置,这是一个数值,指示客户端可能请求的最大允许限制。缺省值为 。None
template- 在可浏览 API 中呈现分页控件时要使用的模板的名称。可以重写以修改呈现样式,或设置为完全禁用 HTML
分页控件。缺省值为 。None"rest_framework/pagination/numbers.html"
四、CursorPagination
1.属性说明
若要设置这些属性,应重写该类,然后启用自定义分页类,如上所述。CursorPagination
page_size= 指示页面大小的数值。如果设置,这将覆盖该设置。默认为与设置键相同的值。PAGE_SIZEPAGE_SIZE
cursor_query_param= 指示“游标”查询参数名称的字符串值。缺省值为 。‘cursor’
ordering= 这应该是一个字符串或字符串列表,指示将对其应用基于游标的分页的字段。例如:。缺省值为
。此值也可能通过在视图上使用来覆盖。ordering = ‘slug’-createdOrderingFilter
template= 在可浏览 API 中呈现分页控件时要使用的模板的名称。可以重写以修改呈现样式,或设置为完全禁用 HTML
分页控件。缺省值为 。None"rest_framework/pagination/previous_and_next.html"
五、自定义设置分页
1.自定义
自定义分页
class LargeResultsSetPagination(PageNumberPagination): page_size = 1000 page_size_query_param = 'page_size' max_page_size = 10000 class StandardResultsSetPagination(PageNumberPagination): page_size = 100 page_size_query_param = 'page_size' max_page_size = 1000
自定义分页返回格式
class CustomPagination(pagination.PageNumberPagination): def get_paginated_response(self, data): return Response({ 'links': { 'next': self.get_next_link(), 'previous': self.get_previous_link() }, 'count': self.page.paginator.count, 'results': data })
1.视图应用分页
class BillingRecordsView(generics.ListAPIView): queryset = Billing.objects.all() serializer_class = BillingRecordsSerializer pagination_class = LargeResultsSetPagination
2.全局应用分页
REST_FRAMEWORK = { 'DEFAULT_PAGINATION_CLASS': 'apps.core.pagination.StandardResultsSetPagination' }
总结
下图为基本使用案例:
PageNumberPagination使用
LimitOffsetPagination使用