APIview:
我们经常写的是view 这个APIview继承了我们的view,并且对请求进来的信息进行设置,
在APIView这个例子中,调用了drf本身的serializer以及Response方法。 APIView对django本身的View进行封装,从上述的代码,这样分析,两者的差别看起来不是很大,但实际中APIView做了很多东西,它定义了很多属性与方法,举几个例子
# 这三个是常用的属性 authentication_classes : 用户登录认证方式,session或者token等等 permission_classes : 权限设置,是否需要登录等 throttle_classes : 限速设置,对用户进行一定的访问次数限制等等。
我们可以点击APIview进去 然后找到其中的奥妙,读取到restframework的具体源码
ViewSetMixin
你平时在写url的比如一个get 有带参数 有不带参数的 那么 我们不仅仅要写两个url还要写两个类
这个时候我们的 就可以继承 ViewSetMixin 来解决了
继承的时候 ViewSetMixin 必须要放在继承的最前面 因为你同时继承 ViewSetMixin 和APIView的时候 他们同时都有as_view()方法 ,这个时候我们就要先用 ViewSetMixin 中的as_view所以他要写在前面
这个是用来让你的url中的as_view中直接设置你的请求的方式的对应的方法 我们在下面可以把我们的post get的请求的方式对应的方法名给改变 我们先导入 :
from rest_framework.viewsets import ViewSetMixin # 这个是用来让你的url中的as_view中直接设置你的请求的方式的对应的方法 我们在下面可以把我们的post get的请求的方式对应的方法名给改变
然后我们下面的vies中的发的方法就可以自定义名字了:
我们的这个方法也要在url中声明:
这就是设置不同的请求方式 对应不同的方法
这样就会省去一个类 两个url对应同一个 请求类
ListModelMixin,GenericViewSet 搭配用法:
class Course(ListModelMixin,GenericViewSet): queryset = models.Course.objects.all() #queryset是封装的方法 def list(self,request,*args,**kwargs): # 这个时候的list就是自带的 也可以重写告诉url他的请求就是list course_list = models.Course.objects.all() # 我们也可以进行重写 queryset
urls:
urlpatterns = [ url(r'courses/$',course.CoursesView.as_view({ 'get':'list'})), # 告诉它 它的get就去找list url(r'courses/(?P\d+)/$',course.CoursesView.as_view({ 'get':'retrieve'}))]