Django rest framework分頁(yè)接口實(shí)現(xiàn)原理解析
如果沒有設(shè)置分頁(yè),django-rest-framework 會(huì)將所有資源類表序列化后返回,如果資源很多,就會(huì)對(duì)網(wǎng)站性能造成影響。為此,我們來(lái)給博客文章列表 API 添加分頁(yè)功能。
django-rest-framework 為分頁(yè)功能提供了多個(gè)輔助類,常用的有:
PageNumberPagination
將資源分為第 1 頁(yè)、第 2 頁(yè)...第 n 頁(yè),使用頁(yè)碼號(hào)請(qǐng)求分頁(yè)結(jié)果。
LimitOffsetPagination
通過(guò) limit 和 offset 兩個(gè)參數(shù)來(lái)控制請(qǐng)求的資源。例如通過(guò)發(fā)送 API 請(qǐng)求:/posts/?offset=20&limit=5,將獲取文章資源列表第 20 篇后的 5 篇文章。如果 offset 以等差數(shù)列遞增,limit 保持不變,則等價(jià)于按頁(yè)碼分頁(yè)。但 offset 和 limit 可以為任意值,因此這種分頁(yè)比 PageNumberPagination 更加靈活。
要使用分頁(yè)功能非常簡(jiǎn)單,只需在項(xiàng)目的配置文件中配置好分頁(yè)選項(xiàng),即可全局啟用分頁(yè)功能。打開 config/common.py 配置文件,寫入如下的分頁(yè)配置:
REST_FRAMEWORK = { # 設(shè)置 DEFAULT_PAGINATION_CLASS 后,將全局啟用分頁(yè),所有 List 接口的返回結(jié)果都會(huì)被分頁(yè)。 # 如果想單獨(dú)控制每個(gè)接口的分頁(yè)情況,可不設(shè)置這個(gè)選項(xiàng),而是在視圖函數(shù)中進(jìn)行配置 'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination', # 這個(gè)選項(xiàng)控制分頁(yè)后每頁(yè)的資源個(gè)數(shù) 'PAGE_SIZE': 10,}
配置完成之后,所有通用視圖函數(shù)或者視圖集生成的資源列表 API,返回的資源列表都會(huì)被分頁(yè)。配置文件中的分頁(yè)設(shè)置將作用于全局,如果某個(gè)視圖函數(shù)或者視圖集不想使用全局配置怎么辦呢?可以在視圖函數(shù)或者視圖集中設(shè)置 pagination_class 屬性,指定需要使用的分頁(yè)輔助類即可。例如將博客文章列表分頁(yè)替換為 limit offset 的分頁(yè)方式,可以這樣設(shè)置:
from rest_framewrok.pagination import PageNumberPaginationclass PostViewSet(viewsets.GenericViewSet): pagination_class = LimitOffsetPagination
這樣,PostViewSet 視圖集將返回 limit offset 分頁(yè)形式的文章列表,而其他視圖或者視圖集仍將使用全局的分頁(yè)配置。
請(qǐng)求文章 api,返回結(jié)果如下:
對(duì)返回結(jié)果的解釋:
count:總資源數(shù)目
next:下一頁(yè)資源的鏈接
previous:上一頁(yè)資源的鏈接
results:當(dāng)前頁(yè)的資源列表
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 基于javaweb+jsp實(shí)現(xiàn)學(xué)生宿舍管理系統(tǒng)2. 多級(jí)聯(lián)動(dòng)下拉選擇框,動(dòng)態(tài)獲取下一級(jí)3. ASP.NET MVC實(shí)現(xiàn)樹形導(dǎo)航菜單4. 如何封裝一個(gè)Ajax函數(shù)5. Java 接口和抽象類的區(qū)別詳解6. Laravel Eloquent ORM高級(jí)部分解析7. IDEA 搭建maven 安裝、下載、配置的圖文教程詳解8. jsp response.sendRedirect()用法詳解9. Spring security 自定義過(guò)濾器實(shí)現(xiàn)Json參數(shù)傳遞并兼容表單參數(shù)(實(shí)例代碼)10. PHP擴(kuò)展之URL編碼、解碼及解析——URLs
