為了更好的顯示回應的書資料,先基本介紹渲染器的使用:現在settings.py的檔案種變數INSTALL_APPS中添加一個app——“rest_framework”,在請求視圖類中回傳資料回應的方式使用from rest_framework.response import Response的類,請求視圖類中可不再使用json.dumps()資料,直接回傳回應Response(ser.data),在講解分頁器的知識會運用到視圖類中,
在Django restframework中,框架提供了三種分頁的方式,以下分點介紹三種分頁方式,
1、看第n頁,每頁顯示m條資料:一般頁碼的請求地址類似于http://localhost:8000/roles/?page=2&size=8
①一般我們可以自定義一個專門為回應的資料提供的分頁序列化器,這里以回應角色資料為例
from rest_framework import serializer class PagerSerializer(serializer.ModelSerializer): class Meta: model = Role fields = "__all__"
②如果不使用分頁器,回應資料的方式就會將所有的資料顯示在前端中
from rest_framework.response import Response class RoleView(APIView): def get(self, *args, **kwargs): roles = Role.object.all() ser = PagerSerializer(instance=roles, many=True) return Response(ser.data)
③使用分頁器需要先匯入相關的分頁器類:from rest_framework.pagination import PageNumberPagination,在查看其中原始碼時,有一些有關于分頁的配置可以在settings.py檔案中配置,如果沒有配置,就會使用這個類相關的默認值,當然我們可以繼承這個類來自定義分頁器類,自定義的類只需要修改分頁相關的屬性值就可以,分頁器類的功能是將得到的所有資料先分號頁,然后再將分好頁的資料放置在序列化中
from rest_framework.pagination import PageNumberPagination class MyPagination(PageNumberPagination): # 頁面顯示的資料條數 page_size = 2 # 頁碼請求地址上的url的get引數名稱 page_query_param = "size" # 頁面允許顯示的最多資料條數 max_page_size = 8
④請求的視圖類中,回傳回應資料的方式發生變化,分頁器物件還提供一些方法,讓回應的資料更豐富一點:增加上、下頁的url地址和查詢的總記錄數,
from rest_framework.response import Response class RoleView(APIView): def get(self, request, *args, **kwargs): roles = Role.object.all() # 將得到的所有資料分好頁 pg = MyPagination() role_pages = pg.paginate_queryset(queryset=roles, request=request, view=self) # 將分好頁的資料放置分頁序列化器中即可 ser = PagerSerializer(instance=role_oages, many=True) # 這種只會回傳資料 # return Response(ser.data) # 這種就會額外顯示上下頁url地址和總記錄數 return pg.get_paginated_response(ser.data)
2、在n個位置后,查看m條資料,一般頁碼的請求地址類似于http://localhost:8000/roles/?offset=2&limit=8,視圖和序列化類都可以不用變,自定義分頁類需要繼承另外一個類,from rest_framework.pagination import LimitOffsetPagination,當然我們可以繼承這個類來自定義分頁器類,自定義的類只需要修改分頁相關的屬性值就可以,分頁器類的功能是將得到的所有資料先分號頁,然后再將分好頁的資料放置在序列化中
from rest_framework.pagination import LimitOffsetPagination class MyPagination(LimitOffsetPagination): # 頁面顯示的資料條數 default_limit = 2 # 頁碼請求地址上的url的get引數名稱 limit_query_param = "limit" offset_query_param = "offset" # 頁面允許顯示的最多資料條數 max_limit = 8
3、加密分頁,只顯示上一頁和下一頁,一般頁碼的請求地址類似于http://localhost:8000/roles/?page=fnew39,序列化類都可以不用變,自定義分頁類需要繼承另外一個類,from rest_framework.pagination import CursorPagination,當然我們可以繼承這個類來自定義分頁器類,自定義的類只需要修改分頁相關的屬性值就可以,分頁器類的功能是將得到的所有資料先分號頁,然后再將分好頁的資料放置在序列化中,由于上一頁和下一頁地址已加密,所以在請求試圖類中就只能使用分頁物件回傳回應的資料:return pg.get_paginated_response()
from rest_framework.pagination import CursorPagination class MyPagination(CursorPagination): # 頁面顯示的資料條數 page_size = 2 # 頁碼請求地址上/下一頁的url的get引數名稱 cursor_query_param = "cursor" # 頁面展示資料數url的get引數名稱 page_size_query_param = "size" # 查詢的資料的排序方式 ordering = "-id" # 頁面允許顯示的最多資料條數 max_page_size = 8
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/136657.html
標籤:Python
上一篇:107.二叉樹的遍歷層次II
