REST framework入坑(9)-ViewSet视图集
是类视图继承自ViewSet, ViewSet内已经封装好了相应的处理方法
class StudentInfoViewSet(viewsets.ViewSet):
def list(self, request):
...
def retrieve(self, request, pk=None):
...
ViewSet视图集类不再实现get(),post()等方法,而是实现动作:
在设置路由时需要将请求方式与动作组织映射: 在as_view中
注意! 如果动作中是对单一对象进行增(put), 删(destory), 改(partial_update), 查(retrieve), 则需要在路径中传入'PK'值
urlpatterns = [
url(r'^students/$', StudentInfoViewSet.as_view({'get':'list'}),
url(r'^students/(?P<pk>\d+)/$', StudentInfoViewSet.as_view({'get': 'retrieve'}) # 需要路径中增加 关键词参数
]
ViewSet中的action属性¶
- 在视图集中, action对象属性里面存放的时Request对象由 请求方式->映射成请求动作
- 在视图集内部 重写一些方法时可以根据不同的action(动作) 进行不同的业务处理
Demo¶
def get_serializer_class(self): # 重写了 得到序列化器对象的方法
if self.action == 'create': # 如果请求的动作是create(post请求),则xxx逻辑
return OrderCommitSerializer
else:
return OrderDataSerializer
ViewSet中自定义动作¶
- 自定义动作使用rest_framework.decorators.action装饰器
- 自定义的动作名称与方法的名字一样,比如定义了自定义的方法名是 'test1' 那么映射的时候,改方法名字对应的动作名也是 ' test1'
- 装饰器会接收两个参数:
- methods: 该action支持的请求方式,列表传递
- detail: 表示是action中要处理的是否是视图资源的对象(即是否通过url路径获取主键):
- True 表示使用通过URL获取的主键对应的数据对象
- False 表示不使用URL获取主键
Demo¶
# 学生信息的修改
@action(methods=['put'], detail=True)
def info(self, request, pk):
# # 根据pk 得到一个数据库的对象
# instance = super().get_object()
#
# # 修改info 只需要一个简单的序列化器即可
# self.serializer_class = student_info_serializer
# info_valid = super().get_serializer(instance,data=request.data)
# info_valid.is_valid(raise_exception=True)
# info_valid.save()
# return Response(info_valid.data)
# 另一种方式
self.serializer_class = student_info_serializer
instance = self.get_object() # 根据pk得到一个序列化器对象
order_valid = self.get_serializer(instance, request.data) # 根据数据库u第项得到一个序列化器对象
order_valid.is_valid() # 数据校验
order_valid.save() # 数据保存
return Response(order_valid.data) # 返回前端
常用视图集父类¶
ViewSet¶
- 继承自APIView,作用也与APIView基本类似, 提供了身份认证、权限校验、流量管理等
- ViewSet中,没有提供任何动作action方法,需要我们自己实现action方法
GenericViewSet¶
- 继承自GenericAPIView, 作用也与GenericAPIVIew类似, 提供了get_object, get_queryset等方法便于列表视图与详情信息视图的开发
ModelViewSet¶
- 继承自GenericAPIVIew,同时包括了ListModelMixin, RetrieveModelMixin, CreateModelMixin, UpdateModelMixin, DestoryModelMixin
ReadOnlyModelViewSet¶
- 继承自GenericAPIVIew, 同时包括了ListModelMixin,RetrieveModelMixin