Django rest framework分页接口实现原理解析

作者:削微寒 时间:2023-08-22 21:26:36 

如果没有设置分页,django-rest-framework 会将所有资源类表序列化后返回,如果资源很多,就会对网站性能造成影响。为此,我们来给博客文章列表 API 添加分页功能。

django-rest-framework 为分页功能提供了多个辅助类,常用的有:

PageNumberPagination

将资源分为第 1 页、第 2 页...第 n 页,使用页码号请求分页结果。

LimitOffsetPagination

通过 limit 和 offset 两个参数来控制请求的资源。例如通过发送 API 请求:/posts/?offset=20&limit=5,将获取文章资源列表第 20 篇后的 5 篇文章。如果 offset 以等差数列递增,limit 保持不变,则等价于按页码分页。但 offset 和 limit 可以为任意值,因此这种分页比 PageNumberPagination 更加灵活。

要使用分页功能非常简单,只需在项目的配置文件中配置好分页选项,即可全局启用分页功能。打开 config/common.py 配置文件,写入如下的分页配置:


REST_FRAMEWORK = {
 # 设置 DEFAULT_PAGINATION_CLASS 后,将全局启用分页,所有 List 接口的返回结果都会被分页。
 # 如果想单独控制每个接口的分页情况,可不设置这个选项,而是在视图函数中进行配置
 "DEFAULT_PAGINATION_CLASS": "rest_framework.pagination.PageNumberPagination",
 # 这个选项控制分页后每页的资源个数
 "PAGE_SIZE": 10,
}

配置完成之后,所有通用视图函数或者视图集生成的资源列表 API,返回的资源列表都会被分页。配置文件中的分页设置将作用于全局,如果某个视图函数或者视图集不想使用全局配置怎么办呢?可以在视图函数或者视图集中设置 pagination_class 属性,指定需要使用的分页辅助类即可。例如将博客文章列表分页替换为 limit offset 的分页方式,可以这样设置:


from rest_framewrok.pagination import PageNumberPagination
class PostViewSet(viewsets.GenericViewSet):
 pagination_class = LimitOffsetPagination

这样,PostViewSet 视图集将返回 limit offset 分页形式的文章列表,而其他视图或者视图集仍将使用全局的分页配置。

请求文章 api,返回结果如下:

Django rest framework分页接口实现原理解析

对返回结果的解释:

count:总资源数目

next:下一页资源的链接

previous:上一页资源的链接

results:当前页的资源列表

来源:https://www.cnblogs.com/xueweihan/p/12930845.html

标签:django,rest,framework,分页
0
投稿

猜你喜欢

  • 谈谈Python中的while循环语句

    2023-08-02 19:07:56
  • Python之re模块详解

    2021-12-18 07:06:24
  • Python装饰器的两种使用心得

    2023-03-17 17:03:23
  • 使用go gin来操作cookie的讲解

    2023-09-12 14:21:49
  • 浅谈sql连接查询的区别 inner,left,right,full

    2024-01-17 08:23:35
  • python中关于py文件之间相互import的问题及解决方法

    2021-08-29 00:29:33
  • 为什么从Python 3.6开始字典有序并效率更高

    2021-03-26 15:29:36
  • fckeditor 修改记录添加行距功能插件

    2022-04-20 23:05:23
  • 通过XSL转换XML文件步骤

    2008-01-27 16:03:00
  • python实现跳表SkipList的示例代码

    2022-04-05 05:01:53
  • vue组件watch属性实例讲解

    2024-05-09 15:19:22
  • 垂直栅格与渐进式行距(下)

    2009-07-09 16:52:00
  • 基于PHP实现用户登录注册功能的详细教程

    2024-04-30 08:50:27
  • python实现石头剪刀布小游戏

    2022-03-22 15:47:36
  • 发布淘宝开源编辑器 KISSY Editor 1.0.0

    2009-10-27 16:20:00
  • 一个asp版的xheditor上传图片服务器端文件

    2009-12-21 14:18:00
  • python 详解如何写flask文件下载接口

    2023-05-04 21:07:06
  • Python编程mac下使用pycharm小技巧

    2022-10-21 19:23:52
  • 用ASP判断客户端浏览器语言自动跳转

    2010-07-09 13:34:00
  • django admin 根据choice字段选择的不同来显示不同的页面方式

    2022-04-26 06:39:10
  • asp之家 网络编程 m.aspxhome.com