DRF框架之mixins

一、ListModelMixin

  • 提供list(request, *args, **kwargs)方法
  • 获取已存在的列表数据(获取多条记录)
  • 获取成功,则返回200 OK

1.引入方式

from rest_framework.mixins import ListModelMixin

2.源码对比

我们可以发现,两处的代码基本一致,因此我们直接拿到使用来优化本地代码

3.使用方法

a.视图类继承ListModelMixin

b.get方法中直接return self.list(request, *args, **kwargs)

    def get(self, request, *args, **kwargs):
        return self.list(request, *args, **kwargs)

二、CreateModelMixin

  • 提供create(request, *args, **kwargs)方法
  • 创建新的模型实例(创建新的记录)
  • 创建成功,返回201 Created
  • 如果请求参数有误,返回400 Bad Request

1.引入方式

from rest_framework.mixins import CreateModelMixin

2.源码对比

依然也是基本一致

3.使用方法

a.视图类继承CreateModelMixin

b.post方法中直接return self.create(request, *args, **kwargs)

    def post(self, request, *args, **kwargs):
        return self.create(request, *args, **kwargs)

三、RetrieveModelMixin

  • 提供retrieve(request, *args, **kwargs)方法
  • 获取已存在的详情数据(一条记录)
  • 获取成功,返回200 OK
  • 如果不存在,则返回404 Not Found

1.引入方式

from rest_framework.mixins import RetrieveModelMixin

2.源码对比

3.使用方法

a.视图类继承RetrieveModelMixin

b.get方法中直接return self.retrieve(request, *args, **kwargs)

    def get(self, request, *args, **kwargs):
        return self.retrieve(request, *args, **kwargs)

四、UpdateModelMixin

  • 提供update(request, *args, **kwargs)方法,用于全更新
  • 提供partail_update(request, *args, **kwargs)方法,用户部分更新,支持PATCH方法
  • 更新已存在的模型实例(更新一条记录)
  • 更新成功,返回200 OK
  • 如果请求参数有误,返回400 Bad Request
  • 如果不存在,返回404 Not Found

1.引入方式

from rest_framework.mixins import UpdateModelMixin

2.源码对比

注:这里有一点不一样,源码中有一个‘partial’,这个表示可以进行部分更新,因此update方法不仅支持全更新,也可以支持部分更新

3.使用方法

a.视图类继承UpdateModelMixin

b.put方法中直接return self.retrieve(request, *args, **kwargs)

    def put(self, request, *args, **kwargs):
        return self.update(request, *args, **kwargs)

五、DestroyModelMixin

  • 提供destroy(request, *args, **kwargs)方法
  • 删除一条已存在的数据(删除一条记录)
  • 删除成功,返回204 No Content
  • 如果不存在,返回404 Not Found

1.引入方式

from rest_framework.mixins import DestroyModelMixin

2.源码对比

3.使用方法

a.视图类继承DestroyModelMixin

b.delete方法中直接return self.retrieve(request, *args, **kwargs)

    def delete(self, request, *args, **kwargs):
        return self.destroy(request, *args, **kwargs)

 

posted @ 2020-07-19 14:01  小公瑾  阅读(1289)  评论(0编辑  收藏  举报