Django REST Framework-如何使用分页 天天看点

2023-04-25 12:30:21  来源:腾讯云

在 Web 开发中,处理大量数据是非常常见的。但是,如果一次性返回所有数据,不仅会增加服务器的负担,而且还会影响客户端的响应时间。为了解决这个问题,分页被广泛应用于 Web 应用程序中,特别是在 RESTful API 中。


(资料图片)

在 Django REST Framework 中,分页器是一种允许我们将查询结果划分为多个页面,并将每个页面的数据返回给客户端的工具。

基于页码的分页器

基于页码的分页器将查询结果划分为多个页面,并使用页码来标识每个页面。客户端可以在查询参数中指定要请求的页面数,以及每个页面返回的对象数量。Django REST Framework 中内置了两种基于页码的分页器:PageNumberPaginationLimitOffsetPagination

PageNumberPagination

PageNumberPagination分页器是基于页码的分页器,允许客户端使用页码和每页返回的对象数量来请求不同的数据范围。以下是一个简单的使用 PageNumberPagination分页器的示例:

from rest_framework.pagination import PageNumberPaginationclass BookPagination(PageNumberPagination):    page_size = 10    page_query_param = "page"    max_page_size = 100class BookViewSet(viewsets.ModelViewSet):    queryset = Book.objects.all()    serializer_class = BookSerializer    pagination_class = BookPagination

在这个例子中,我们创建了一个名为 BookPagination的分页器类,并指定了默认的页面大小为 10,并将 page_query_param属性设置为 page,以便使用 page参数作为页码参数。我们还为客户端指定了可以在查询参数中使用的 pagepage_size参数,并设置了最大页面大小为 100。最后,我们将 BookPagination分页器类添加到 BookViewSet视图集合中。

现在,当客户端发起请求时,我们的 BookViewSet视图集合将使用 BookPagination分页器将查询结果划分为多个页面,并将每个页面的数据返回给客户端。客户端可以在查询参数中指定 pagepage_size参数来请求不同的数据范围。

LimitOffsetPagination

LimitOffsetPagination分页器也是一种基于页码的分页器,但与 PageNumberPagination不同的是,它允许客户端指定一个偏移量和每页返回的对象数量来请求数据。以下是一个简单的使用 LimitOffsetPagination分页器的示例:

from rest_framework.pagination import LimitOffsetPaginationclass BookPagination(LimitOffsetPagination):    default_limit = 10    limit_query_param = "limit"    offset_query_param = "offset"    max_limit = 100class BookViewSet(viewsets.ModelViewSet):    queryset = Book.objects.all()    serializer_class = BookSerializer    pagination_class = BookPagination

在这个例子中,我们创建了一个名为 BookPagination的分页器类,并指定了默认的页面大小为 10,并将 limit_query_paramoffset_query_param分别设置为 limitoffset,以便客户端可以使用 limitoffset参数来请求数据。我们还指定了最大限制为 100,并将 BookPagination分页器类添加到 BookViewSet视图集合中。

现在,当客户端发起请求时,我们的 BookViewSet视图集合将使用 LimitOffsetPagination分页器将查询结果划分为多个页面,并将每个页面的数据返回给客户端。客户端可以在查询参数中指定 limitoffset参数来请求不同的数据范围。

基于游标的分页器

基于游标的分页器与基于页码的分页器不同,它使用一个游标来标识要返回的数据范围。在客户端发送第一次请求时,服务器返回一组数据和一个游标。客户端使用这个游标来请求下一组数据。以下是一个简单的使用 CursorPagination分页器的示例:

from rest_framework.pagination import CursorPaginationclass BookPagination(CursorPagination):    page_size = 10    ordering = "title"class BookViewSet(viewsets.ModelViewSet):    queryset = Book.objects.all()    serializer_class = BookSerializer    pagination_class = BookPagination

在这个例子中,我们创建了一个名为 BookPagination的分页器类,并指定了默认的页面大小为 10,并将 ordering属性设置为 title,以便按标题排序。最后,我们将 BookPagination分页器类添加到 BookViewSet视图集合中。

现在,当客户端发起请求时,我们的 BookViewSet视图集合将使用 CursorPagination分页器将查询结果划分为多个页面,并将每个页面的数据返回给客户端。客户端可以使用 nextprevious参数来请求下一页和上一页。

在 Django REST Framework 中,分页器是一种将查询结果划分为多个页面并将每个页面的数据返回给客户端的工具。Django REST Framework 中内置了两种分页器,即基于页码的分页器和基于游标的分页器。在使用分页器时,我们可以指定默认的页面大小、页面参数和最大页面大小等属性,以及按特定的字段排序等选项。