绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
Rest-framework专栏讲解(八):ViewSet
2020-06-28 13:27:36

MedusaSorcerer的博客


点击跳转到 Rest-Framework 专栏目录

Django 项目的 ORM(Object Relational Mapping, 对象关系映射) 可以给我们省略构造 SQL 查询语句的麻烦, 但是对于试图, 我们已经构建了 Model 的情况下依旧需要创造一些逻辑代码, 那已知这些封装, 我们可以再对代码简化。

ViewSet 操作

在标准的接口中, 提供了标准的创建/检索/更新/删除实例对象的路由, 如:

class UserViewSet(viewsets.ViewSet):
    """
    Example empty viewset demonstrating the standard
    actions that will be handled by a router class.

    If you're using format suffixes, make sure to also include
    the `format=None` keyword argument for each action.
    """

    def list(self, request):
        pass

    def create(self, request):
        pass

    def retrieve(self, request, pk=None):
        pass

    def update(self, request, pk=None):
        pass

    def partial_update(self, request, pk=None):
        # 不常用
        pass

    def destroy(self, request, pk=None):
        pass
复制代码

在分发期间你可以使用以下属性:

  • basename:用于创建 URL 的基础名称
  • action:当前操作的动作名称字符串(如 list)
  • detail:是否返回列表/详情信息的布尔值
  • suffix:视图集类型的显示后缀
  • name:视图集的显示名称, 会与 suffix 参数互斥
  • description:单个试图的显示描述

API参考

ViewSet 集成自 APIView, 你可以使用任何标准属性获取数值帮助 API 构建, 如 permission_classes, authentication_classes 来帮助试图控制访问策略。

GenericViewSet 是继承自 GenericAPIView, 并提供了 get_objectget_queryset 的方法以及其他视图行为的方法。

ModelViewSet 是继承自 GenericAPIView, 并支持 .list(), .retrieve(), .create(), .update(), .partial_update().destroy() 方法的视图类, 通常你需要指定 querysetserializer_class 两个属性。

分享好友

分享这个小栈给你的朋友们,一起进步吧。

MedusaSorcerer
创建时间:2020-06-29 16:36:50
学无止境, 学无止尽。
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

栈主、嘉宾

查看更多
  • zuike2000
    栈主
戳我,来吐槽~