欢迎访问我的博客专题
源码可访问 Github 查看
分页功能
修改GoodsListView
视图显示所有商品,用于之后的分页功能。
class GoodsListView(generics.ListAPIView):
"""
显示所有的商品列表
"""
queryset = Goods.objects.all()
serializer_class = GoodsSerializer
全局分页配置
分页API可以支持以下两种方式:
- 作为响应内容的一部分提供的分页链接。
- 包含在响应头中的分页链接,如内容范围或链接。
只有在使用 generic views 或 viewsets 时才会自动执行分页。如果使用常规的APIView,则需要自己调用分页API,以确保返回分页响应。请参阅mixin的源代码,mixins.ListModelMixin
和 generics.GenericAPIView
类中的示例。
分页可以通过将分页类设置为None来关闭。
REST框架API的任何全局设置都保存在一个名为REST_FRAMEWORK
的配置字典中。访问 https://www.django-rest-framework.org/api-guide/pagination/#pagenumberpagination 可查看示例。
分页样式可以使用DEFAULT_PAGINATION_CLASS
和PAGE_SIZE
设置,默认这两个值都是None
。例如,要使用内置的 限制/偏移 分页,在settings.py模块中添加以下内容:
# DRF配置
REST_FRAMEWORK = {
'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
'PAGE_SIZE': 5
}
单独设置分页
在GenericAPIView
子类上,还可以设置pagination_class
属性,以根据每个视图选择PageNumberPagination
。如果希望修改分页样式的特定方面,则需要覆盖分页类中的一个,并设置要更改的属性。
访问 https://www.django-rest-framework.org/api-guide/pagination/#modifying-the-pagination-style 进行自定义
配置:
PageNumberPagination
类包含许多属性,可以覆盖这些属性来修改分页样式。
要设置这些属性,应该覆盖PageNumberPagination
类,然后像上面那样启用自定义分页类。
-
django_paginator_class
- 要使用的Django Paginator类。默认是django.core.paginator.Paginator
,对于大多数用例来说都是可以的。 -
page_size
- 指示页面大小的数值。如果设置,则会覆盖PAGE_SIZE
设置。默认值为与 settings.py 中PAGE_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中呈现分页控件时使用的模板的名称。可以重写以修改呈现样式,也可以将其设置为None
以完全禁用HTML分页控件。默认为"rest_framework/pagination/numbers.html"
.
from rest_framework import generics
from rest_framework.pagination import PageNumberPagination
from .models import Goods
from .serializers import GoodsSerializer
class GoodsPagination(PageNumberPagination):
page_size = 3 # 默认每一页个数
page_size_query_param = 'page_size'
page_query_param = 'p' # 参数?p=xx
max_page_size = 36 # 最大指定每页个数
class GoodsListView(generics.ListAPIView):
"""
显示所有的商品列表
"""
queryset = Goods.objects.all()
serializer_class = GoodsSerializer
pagination_class = GoodsPagination
访问 http://127.0.0.1:8000/goods/?format=api&p=2 可以查看第二页
可以指定每页大小,比如 http://127.0.0.1:8000/goods/?format=api&p=2&page_size=10 ,总的页数就发生变化了。
错误警告:UnorderedObjectListWarning
\lib\site-packages\rest_framework\pagination.py:198: UnorderedObjectListWarning: Pagination may yield inconsistent results with an unordered object_list:
解决方法
方法一:
在需要进行查询的模型类中 增加ordering
参数
class Meta:
# ...
ordering = ['id']
方法二:
在需要进行查询的语句中增加order_by
排序
class GoodsListView(generics.ListAPIView):
"""
显示所有的商品列表
"""
queryset = Goods.objects.all().order_by('id')
serializer_class = GoodsSerializer
# ...
去除全局分页配置
修改 settings.py ,可以取消默认分页,防止影响之后商品分类的结果
# DRF配置
REST_FRAMEWORK = {
'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
# 'PAGE_SIZE': 5
}