视图家族

一、views视图类

1、APIView类

功能:

  1. 拥有view的所有属性和方法;
  2. 重写as_view,禁用csrf;
  3. 重写dispatch,分发任务,五大模块对数据进行二次封装;
  4. 设定了一系列类属性。

2、GenericAPIView类(generics中)

特点:

  1. 继承APIView,所以拥有APIView的所有属性和方法;
  2. get_queryset方法,配置queryset类属性,提供视图类相关的Models;
  3. 在第二条的基础上,get_object方法,配置look_url_kwarg类属性,提供视图类的具体Model;
  4. get_serializer方法,配置serializer_class类属性,提供视图类相关的序列化对象。

分析:

class GenericAPIView(views.APIView):

    def get_queryset(self):
获取自定义类中设定的queryset对象。 def get_serializer(self):
调用get_serializer_class方法;
获取自定义类中设定的serializer_class序列化类 def get_object(self):
首先通过get_queryset获取自定义类中给定的queryset对象;
然后获取自定义类中设定的lookup_url_kwarg过滤参数;
如果没有就使用默认的 lookup_field='pk' 过滤参数;
使用过滤参数对queryset对象进行过滤; 因此,在继承GenericAPIView来自定义类时,需要定义queryset、serializer_class及lookup_url_kwarg(非必要)

目的:

视图中的增删改查逻辑相似,但操作的资源不一致,操作资源包括:[操作单个资源对象]、[操作多个资源对象]以及[资源相关的序列化类],将这三者形成配置,那操作逻辑就一致,就可以进行封装。

总结:

GenericAPIView就是在APIView基础上额外提供了三个方法,三个类属性,如果不配合视图工具类,体现不出优势。

二、mixins类:视图辅助工具

特点:

  1. 需要配合GenericAPIView类使用;
  2. 将单查、群查、单增、群增、单整体改,单局部改所对应的六个接口写成retrieve、list、create、update、partial_update、destroy六个方法,封装到五个类中;
  3. 以上六个方法中需要用到GenericAPIView提供的三大方法,因此需要GenericAPIView类的配合;
  4. 默认返回的只有序列化后的对象包含的内容。

1、RetrieveModelMixin

单查

class RetrieveModelMixin:
def retrieve(self, request, *args, **kwargs):
实现单查。 如果可以检索对象,则返回 200 OK 响应;
将该对象的序列化表示作为响应的主体。 否则将返回 404 Not Found。

2、ListModelMixin

群查

class ListModelMixin:
def list(self, request, *args, **kwargs):
实现群查; 如果查询集被填充了数据,则返回 200 OK 响应;
将查询集的序列化表示作为响应的主体。
相应数据可以任意分页。

3、CreateModelMixin

单增

class CreateModelMixin:
def create(self, request, *args, **kwargs):
实现单增。 如果创建了一个对象,将返回一个 201 Created 响应;
将该对象的序列化表示作为响应的主体。 如果为创建对象提供的请求数据无效,将返回 400 Bad Request;
其中错误详细信息作为响应的正文。

4、UpdateModelMixin

单整体改和单局部改

class UpdateModelMixin:
def update(self, request, *args, **kwargs):
完成单整体改; def partial_update(self, request, *args, **kwargs):
完成单局部改; 如果更新成功,将返回一个 200 OK 响应;
将对象的序列化表示作为响应的主体。 如果更新失败,将返回一个 400 Bad Request 响应;
错误详细信息作为响应的正文。

5、DestroyModelMixin

单删

class DestroyModelMixin:
def destroy(self, request, *args, **kwargs):
完成单删;
如果删除对象,则返回 204 No Content 响应;
否则返回 404 Not Found。

三、generics类:包含辅助工具的通用视图类

九个通用视图。

这通常是你真正用到的那些,除非你需要深度定制的行为。

这些视图类可以从 rest_framework.generics导入。

class RetrieveAPIView(mixins.RetrieveModelMixin,
GenericAPIView):
完成单查
def get(self, request, *args, **kwargs):
return self.retrieve(request, *args, **kwargs) class ListAPIView(mixins.ListModelMixin,
GenericAPIView):
完成群查
def get(self, request, *args, **kwargs):
return self.list(request, *args, **kwargs) class CreateAPIView(mixins.CreateModelMixin,
GenericAPIView):
完成单增
def post(self, request, *args, **kwargs):
return self.create(request, *args, **kwargs) class UpdateAPIView(mixins.UpdateModelMixin,
GenericAPIView):
单整体改
def put(self, request, *args, **kwargs):
return self.update(request, *args, **kwargs) 单局部改
def patch(self, request, *args, **kwargs):
return self.partial_update(request, *args, **kwargs) class DestroyAPIView(mixins.DestroyModelMixin,
GenericAPIView):
完成单删
def delete(self, request, *args, **kwargs):
return self.destroy(request, *args, **kwargs) class ListCreateAPIView(mixins.ListModelMixin,
mixins.CreateModelMixin,
GenericAPIView):
群查
def get(self, request, *args, **kwargs):
return self.list(request, *args, **kwargs)
单增
def post(self, request, *args, **kwargs):
return self.create(request, *args, **kwargs) class RetrieveUpdateAPIView(mixins.RetrieveModelMixin,
mixins.UpdateModelMixin,
GenericAPIView):
单查
def get(self, request, *args, **kwargs):
return self.retrieve(request, *args, **kwargs)
单整体改
def put(self, request, *args, **kwargs):
return self.update(request, *args, **kwargs)
单局部改
def patch(self, request, *args, **kwargs):
return self.partial_update(request, *args, **kwargs) class RetrieveDestroyAPIView(mixins.RetrieveModelMixin,
mixins.DestroyModelMixin,
GenericAPIView):
单查
def get(self, request, *args, **kwargs):
return self.retrieve(request, *args, **kwargs)
单删
def delete(self, request, *args, **kwargs):
return self.destroy(request, *args, **kwargs) class RetrieveUpdateDestroyAPIView(mixins.RetrieveModelMixin,
mixins.UpdateModelMixin,
mixins.DestroyModelMixin,
GenericAPIView):
单查
def get(self, request, *args, **kwargs):
return self.retrieve(request, *args, **kwargs)
单整体改
def put(self, request, *args, **kwargs):
return self.update(request, *args, **kwargs)
单局部改
def patch(self, request, *args, **kwargs):
return self.partial_update(request, *args, **kwargs)
单删
def delete(self, request, *args, **kwargs):
return self.destroy(request, *args, **kwargs)

四、viewsets视图集

包含:

一个工具类、两个视图集基类、两个视图集子类

1、作用

其中一个工具类重写了as_view方法,将自己定义的群查和单查方法的函数地址赋给get方法,这样就可以在路由来调用时,主动识别调用单查还是群查。

2、如何使用

路由中:as_view({'get':'list'}) 传入的{'get':'list'}就被actions接收,原理是将get请求映射给视图类的list函数进行处理。

class ViewSetMixin:
视图集都继承了ViewSetMixin类,该类重写了as_view方法,相比APIView的as_view方法,额外多出了一个参数:actions。 @classonlymethod
def as_view(cls, actions=None, **initkwargs): class ViewSet(ViewSetMixin, views.APIView): pass class GenericViewSet(ViewSetMixin, generics.GenericAPIView): pass class ReadOnlyModelViewSet(mixins.RetrieveModelMixin,
mixins.ListModelMixin,
GenericViewSet): pass class ModelViewSet(mixins.CreateModelMixin,
mixins.RetrieveModelMixin,
mixins.UpdateModelMixin,
mixins.DestroyModelMixin,
mixins.ListModelMixin,
GenericViewSet): pass
  1. GenericViewSet和ViewSet两个基类有什么区别:

    • GenericViewSet(ViewSetMixin,GenericAPIView):该分支严格满足资源接口
    • ViewSet(ViewSetMixin,APIView):该分支满足的接口与资源Model类关系不是特别密切(登录接口、短信验证码接口)
  2. ReadOnlyModelViewSet,ModelViewSet两个视图集子类,就是做个一堆mixin与GenericViewSet相结合,自己在urls文件中配置as_view的action分发。

3、ModelViewSet的不合理之处及解决方法

不合理之处:

  1. 没有群增,群整体改,群局部改,群删四个接口
  2. 删除操作视图集默认走的destroy方法是将资源从数据库中删除,通常一个做字段is_delete字段修改表示删除
  3. 响应的结果只有数据,没有数据状态码和状态信息

解决方法:

  1. 群整体改,群局部改,全删三个接口可以独立成三个方法

    def many_update(self, request, *args, **kwargs):
    pass
    def many_partial_update(self, request, *args, **kwargs):
    pass
    def many_destroy(self, request, *args, **kwargs):
    pass
    • 群增与单增必须公用一个接口,都要走create方法 - 重写create方法,用逻辑进行拆分
    def create(self, request, *args, **kwargs):
    request_data = request.data
    if isinstance(request_data, list):
    car_ser = self.get_serializer(data=request_data, many=True)
    car_ser.is_valid(raise_exception=True)
    car_obj = car_ser.save()
    return APIResponse(msg='群增成功', results=self.get_serializer(car_obj, many=True).data) return super().create(request, *args, **kwargs)
  2. destroy方法是完成is_delete字段值修改 - 重写destroy方法,自定义实现体

    def destroy(self, request, *args, **kwargs):
    car_obj = self.get_object()
    car_obj.is_delete = True
    car_obj.save()
    return APIResponse(msg='删除成功')
  3. 让群查有状态码和状态信息 - 重写list方法

    def list(self, request, *args, **kwargs):
    response = super().list(request, *args, **kwargs)
    return APIResponse(results=response.data)

路由层补充

路由的其他写法:SimpleRouter

会遇到,看到了要认识:

# urls.py
from rest_framework.routers import SimpleRouter
router = SimpleRouter()
router.register('v2/cars', views.CarModelViewSet, basename='car') urlpatterns = [
url(r'^v1/cars/$', views.CarAPIView.as_view()), url(r'', include(router.urls))
]
/
urlpatterns += router.urls
/
urlpatterns = router.urls

DRF 视图家族及路由层补充的更多相关文章

  1. DRF视图集的路由设置

    在使用DRF视图集时,往往需要配一大堆路由,例如: # views.py class DepartmentViewSet(ListModelMixin,CreateModelMixin,Retriev ...

  2. day73:drf:drf视图相关类&路由Routers&创建虚拟环境

    目录 1.APIView 2.GenericAPIView:通用视图类 3.5个视图扩展类:ListModelMixin,CreateModelMixin,RetrieveModelMixin,Upd ...

  3. drf框架 - 视图家族 | GenericAPIView | mixins | generics | viewsets

    视图家族 view:视图 generics:工具视图 mixins:视图工具集 viewsets:视图集 学习曲线: APIView => GenericAPIView => mixins ...

  4. django之表设计、路由层等

    图书管理系统表的设计 from django.db import models # Create your models here. class Book(models.Model): title = ...

  5. drf二次封装response-APIViews视图家族-视图工具集-工具视图-路由组件

    视图类传递参数给序列化类 (1).在视图类中实例化 序列化对象时,可以设置context内容. (2).在序列化类中的局部钩子.全局钩子.create.update方法中,都可以用self.conte ...

  6. Django-1版本的路由层、Django的视图层和模板层

    一.Django-1版本的路由层(URLconf) URL配置(URLconf)就像Django所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表:我们就是以这种方式告诉Dja ...

  7. Django系列(二):Django的路由层,视图层和模板层

    1.Django的路由层 URL配置(URLconf)就像Django所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表:我们就是以这种方式告诉Django,对于客户端发来的某 ...

  8. 视图家族 & 路由组件

    目录 视图家族 & 路由组件 视图集与路由组件 基于 GenericAPIView 的十大接口 基于 generics 包下工具视图类的六大基础接口 视图集 路由组件:必须配合视图集使用 自定 ...

  9. Django之路由层和视图层详解

    路由层 首先我们来看一下,路由层都有哪些东西,其实你看django很人性化,将所有的介绍都放在了简介里面,不信,你看

随机推荐

  1. linux(2)系统目录结构

    前言 平常linux系统用的也不少,那么linux下的每个目录都是用来干什么的,小伙伴们有仔细研究过吗?让我们来了解下吧 Linux 系统目录结构 登录系统后,在当前命令窗口下输入命令: [root@ ...

  2. fsck获取文件的block信息和位置信息

    原文链接:lxw的大数据田地 » hdfs fsck命令查看HDFS文件对应的文件块信息(Block)和位置信息(Locations) 关键字:hdfs fsck.block.locations 在H ...

  3. 【C#】对两张图片进行矩阵运算会怎么样?

    对两张图片进行矩阵运算会怎么样? 在学习<线性代数>的矩阵运算时,突然想到图片也可以算是一种矩阵,那么对图片进行矩阵的运算会出现什么样的效果呢?为了满足好奇,便用C#写了个对图片进行矩阵运 ...

  4. 2020Nowcode多校 Round9 B.Groundhog and Apple Tree

    题意 给一棵树 初始\(hp=0\) 经过一条边会掉血\(w_{i}\) 第一次到达一个点可以回血\(a_{i}\) 在一个点休息\(1s\)可以回复\(1hp\) 血不能小于\(0\) 每条边最多经 ...

  5. 【bzoj 2339】[HNOI2011]卡农(数论--排列组合+逆元+递推)

    题意:从编号为 1~N 的音阶中可选任意个数组成一个音乐片段,再集合组成音乐篇章.要求一个音乐篇章中的片段不可重复,都不为空,且出现的音符的次数都是偶数个.问组成 M 个片段的音乐篇章有多少种.答案取 ...

  6. Successor HDU - 4366 分块

    代码+注释: 1 /* 2 题意: 3 一共有n个人,其中0号是总裁(金字塔顶尖).后面输入其他n-1个人的信息啊a.b.c,分别代表第i个人的上级是a,他的 4 忠诚度为b,他的能力为c.后面有m次 ...

  7. Centos7 搭建Nginx+rtmp+hls直播推流服务器

    1 准备工具 使用yum安装git [root~]# yum -y install git 下载nginx-rtmp-module,官方github地址 // 通过git clone 的方式下载到服务 ...

  8. Dapr微服务应用开发系列2:Hello World与SDK初接触

    题记:上篇介绍了Dapr的环境配置,这次我们来动手尝试一下Dapr应用的开发 Hello World Dapr应用的Hello World其实和其他的Hello World一样简单: 首先用你喜欢的语 ...

  9. 实战交付一套dubbo微服务到k8s集群(5)之使用Jenkins进行持续构建交付dubo服务的提供者

    1.登录到jenkins,新建一个项目 2.新建流水线 3.设置保留的天数及份数 4.添加第一个参数:设置项目的名称 5.添加第二个参数:docker镜像名称 6.添加第三个参数:项目所在的git中央 ...

  10. Chapter Zero 0.1.1 计算机硬件五大单元

    计算机硬件的五大单元 先从CPU说起,CPU的全称如下: 中央处理器(Central Processing Unit,CPU) CPU作为一个特定功能的芯片,内含微指令集, 主机的功能差异,主要参考C ...