rest_framework.views.APIView
APIView
是REST framework提供的全部視圖的基類,繼承自Django的View
父類。前端
APIView
與View
的不一樣之處在於:數據庫
Request
對象,而不是Django的HttpRequeset
對象;Response
對象,視圖會爲響應數據設置(render)符合前端要求的格式;APIException
異常都會被捕獲到,而且處理成合適的響應信息;支持定義的屬性後端
在APIView
中仍以常規的類視圖定義方法來實現get() 、post() 或者其餘請求方式的方法。api
舉例:iview
from rest_framework.views import APIView from rest_framework.response import Response # url(r'^books/$', views.BookListView.as_view()), class BookListView(APIView): def get(self, request): books = BookInfo.objects.all() serializer = BookInfoSerializer(books, many=True) return Response(serializer.data)
rest_framework.generics.GenericAPIView
繼承自APIVIew
,主要增長了操做序列化器和數據庫查詢的方法,做用是爲下面Mixin擴展類的執行提供方法支持。一般在使用時,可搭配一個或多個Mixin擴展類。post
提供的關於序列化器使用的屬性與方法url
屬性:spa
方法:rest
get_serializer_class(self)code
當出現一個視圖類中調用多個序列化器時,那麼能夠經過條件判斷在get_serializer_class方法中經過返回不一樣的序列化器類名就能夠讓視圖方法執行不一樣的序列化器對象了。
返回序列化器類,默認返回serializer_class
,能夠重寫,例如:
def get_serializer_class(self): if self.request.user.is_staff: return FullAccountSerializer return BasicAccountSerializer
返回序列化器對象,主要用來提供給Mixin擴展類使用,若是咱們在視圖中想要獲取序列化器對象,也能夠直接調用此方法。
注意,該方法在提供序列化器對象的時候,會向序列化器對象的context屬性補充三個數據:request、format、view,這三個數據對象能夠在定義序列化器時使用。
提供的關於數據庫查詢的屬性與方法
屬性:
方法:
get_queryset(self)
返回視圖使用的查詢集,主要用來提供給Mixin擴展類使用,是列表視圖與詳情視圖獲取數據的基礎,默認返回queryset
屬性,能夠重寫,例如:
def get_queryset(self): user = self.request.user return user.accounts.all()
get_object(self)
返回詳情視圖所需的模型類數據對象,主要用來提供給Mixin擴展類使用。
在試圖中能夠調用該方法獲取詳情信息的模型類對象。
若詳情訪問的模型類對象不存在,會返回404。
該方法會默認使用APIView提供的check_object_permissions方法檢查當前對象是否有權限被訪問。
舉例:
# url(r'^books/(?P<pk>\d+)/$', views.BookDetailView.as_view()), class BookDetailView(GenericAPIView): queryset = BookInfo.objects.all() serializer_class = BookInfoSerializer def get(self, request, pk): book = self.get_object() # get_object()方法根據pk參數查找queryset中的數據對象 serializer = self.get_serializer(book) return Response(serializer.data)
其餘能夠設置的屬性