优化REST Framework 的 路由 APIView 和ViewSetMixin

 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<pk>\d+)/$',course.CoursesView.as_view({'get':'retrieve'}))
]

 

posted @ 2018-08-08 20:36  可爱的红领巾  阅读(339)  评论(0编辑  收藏  举报