rest_framework.mixins

请求业务 的 5 种实现

​ mixin(混合类):不能单独使用,和其它类搭配起来使用(利用了Python支持多继承)

  • rest_framework.mixins imput 业务的 主要逻辑都在这里

    • CreateModelMixin 创建对象 post 请求
    • ListModelMixin 查询所有的对象 get请求
    • RetrieveModelMixin 查询一个对象 get请求
    • UpdateModelMixin 更改一个对象 put 请求
    • DestroyModelMixin 删除一个请求 delete 请求

rest_framework.generics 实际使用时 需要调用的类

实际操作时根据 相应的需求来查询并继承

​ 定义的类的 视图操作 上面实现了 orm 操作 GenericAPIView

​ 以及 增删改查查的 操作 分类 多种选项 根据实际情况分类继承

rest_framework.viewsets 没有实际的 操作 只是对类进行了 归类的继承 方便使用

  • rest_framework.viewsets`中还封装好了其他的方法 一次性继承

    • from rest_framework.viewsets import ReadOnlyModelViewSet
    • ReadOnlyModelViewSet 封住了 两个查询的 方法 以及视图配置
    • ModelViewSet 封装了 视图配置以及5 个方法 直接继承这一个方法 完成5中操作
  • 使用 ModelViewSet 合成的写法 就要

    • 对路由进行设置 actions={'get':'list' .....} 进行归类

      url(r'authors/$', views.AuthorViewSet.as_view(
      actions={'get': 'list', 'post': 'create'})),
      # 作者列表
      url(r'authors/(?P<pk>\d+)/$', views.AuthorViewSet.as_view(
      actions={'get': 'retrieve', 'put': 'update', 'delete': 'destroy'})),
      # 作者详情
    • 或者使用 集成的写法 只写一个路由

      from rest_framework.routers import urlpatterns
      
      router = DefaurtRouter()
      
      # 设置路由应对应的 视图
      router.register('authors', views.AuthorViewSet)
      router.register('books', views.BooksViewSet) # 将生成的 路由添加到 urlpatterns 中 默认路由
      urlpatterns += router.urls

简化写法

视图只需要写一个就可以完成相应的操作

视图中 注意在路由中也要做一些修改

分开的写法:

# 导入配置类
from rest_framework.viewsets import GenericViewSet # 分开写 可以通过继承方式来 实现某种功能 路有中也必须分开写
导入5 个 混合类 配合使用
from rest_framework.mixins import CreateModelMixin, ListModelMixin, UpdateModelMixin, DestroyModelMixin, \
RetrieveModelMixin # 有 get post 请求
class BooksList(GenericViewSet, CreateModelMixin, ListModelMixin):
queryset = models.Books.objects.all()
serializer_class = BooksModelSerializer # get put delete 请求
class BookDetail(GenericViewSet, UpdateModelMixin, DestroyModelMixin, RetrieveModelMixin):
queryset = models.Books.objects.all()
serializer_class = BooksModelSerializer

写成一个的 写法

from rest_framework.viewsets import ModelViewSet
# 导入rest_framework已经 封装好的 5 种请求类 以及配置类
# 直接继承 就可以 使用返回 5 中请求
class AuthorViewSet(ModelViewSet):
"""
list()
create()
retrieve()
update()
destroy()
"""
queryset = models.Author.objects.all()
serializer_class = AuthorModelSerializer

路由中

一定要写 actions={}的 参数 字典中的 key 对应小写的 请求方式 value 对应请求 应该执行的 方法

如果 忘了 可以在 rest_framework.viewsets 中 查看 具体 对应的 方法名字

url(r'authors/$', views.AuthorViewSet.as_view(actions={'get': 'list', 'post': 'create'})),  # 作者列表
url(r'authors/(?P<pk>\d+)/$', views.AuthorViewSet.as_view(
actions={'get': 'retrieve', 'put': 'update', 'delete': 'destroy'})
), # 作者详情

路由也可以 写成一个 由系统自动分配路由 urlpatterns

from rest_framework.routers import urlpatterns

router = DefaurtRouter(
# 设置路由应对应的 视图
router.register('authors', views.AuthorViewSet)
router.register('books', views.BooksViewSet)
将生成的 路由添加到 urlpatterns 中 默认路由
urlpatterns += router.urls #####此方法 可以在路由中 使用 .json 直接获取json 数据
http://127.0.0.1:8000/books.json

从地址栏获取 ? 参数

request.query_params.get('category')

generics

使用 封装了 所有的 增删改查查 操作

  • from rest_framework import generics

    • 直接继承内部封装的方法

    • 不必在 路由中 写 actions={'get': 'list', 'post': 'create'} 来定义 具体的 对应操作

    • class ListAPIView(mixins.ListModelMixin,
      GenericAPIView):
      """
      Concrete view for listing a queryset.
      """
      def get(self, request, *args, **kwargs):
      return self.list(request, *args, **kwargs)
    • 类中已经定义好了 方法 调用对应的 Mixin 类中的 方法

    **只需要 定义 **

    •     queryset = models.Course.objects.all()
      serializer_class = CourseModelSerializer

Django-rest-framework 接口实现 rest_framework 中有已经定义好的 工具类 mixins generics viewsets的更多相关文章

  1. Django Rest framework 之 权限

    django rest framework 之 认证(一) django rest framework 之 权限(二) django rest framework 之 节流(三) django res ...

  2. Django Rest framework 之 视图

    RESTful 规范 django rest framework 之 认证(一) django rest framework 之 权限(二) django rest framework 之 节流(三) ...

  3. django rest framework 详解

    Django REST framework 是用于构建Web API 的强大而灵活的工具包. 我们可能想使用REST框架的一些原因: Web浏览API对于开发人员来说是一个巨大的可用性. 认证策略包括 ...

  4. Django REST framework完全入门

    Django REST framework 一个强大灵活的Django工具包,提供了便捷的 REST API 开发框架 我们用传统的django也可以实现REST风格的api,但是顶不住Django ...

  5. Django REST Framework 最佳实践

    Django REST framework 是一个强大且灵活的工具包,用以构建Web APIs. 为什么要使用REST framework? - 在线可视的API,对于赢得你的开发者们十分有用 - 验 ...

  6. Django REST framework - 视图

    目录 Django REST framework 视图GenericAPIView GenericAPIView 例子 属性 混入 具体视图类 自定义基类 Django REST framework ...

  7. Java实现单词自定义排序|集合类、工具类排序、comparable、comparator接口

    课题 针对单词进行排序,先按字母的长度排序,长者在前: 在长度相等的情况下,按字典降序排序. 例如,有单词序列"apple banana grape orange",排序后输出结果 ...

  8. day71:drf:API接口&Restful API规范&Django Rest Framework&drf中的序列化和反序列化功能

    目录 1.web应用模式 2.API接口 3.Restful API规范 4.序列化 5.Django Rest Framework 1.drf的简单介绍 2.drf的特点 3.如何安装drf 4.d ...

  9. [Django REST framework - 自动生成接口文档、分页]

    [Django REST framework - 自动生成接口文档.分页] 自动生成接口文档 # 后端人员写好接口,编写接口文档,给前端人员看,前端人员依照接口文档开发 # 公司里主流 -后端,使用w ...

随机推荐

  1. ASP.NET MVC 学习笔记-2.Razor语法

    1.         表达式 表达式必须跟在“@”符号之后, 2.         代码块 代码块必须位于“@{}”中,并且每行代码必须以“:”结尾.代码块中定义的变量可能会被同一个域中的其他块使用. ...

  2. spring2.0:The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone. You must configure either th

    提示系统时区出现错误,可以在mysql中执行命令: set global time_zone='+8:00' 或者在数据库驱动的url后加上serverTimezone=UTC参数 jdbc:mysq ...

  3. JS实现异步提交

    什么是XMLHttpRequest? XMLHttpRequest对象用于在后台与服务器交换数据 XMLHttpRequst的作用 在不重新加载页面的情况下更新网页 在页面已加载后从服务器请求数据 在 ...

  4. 发生服务器错误: Error loading MySQLdb module: libmysqlclient.so.18: cannot open shared object file: No such file or directory

    在hue上配置Mysql的时候,出现的错误:  发生服务器错误: Error loading MySQLdb module: libmysqlclient.so.18: cannot open sha ...

  5. 对比JavaScript中的Continue和Break

    译者按: 最好是不用,不过基础知识要掌握. 原文: JavaScript: Continue vs Break - Learn the difference between the continue ...

  6. wepy框架须知

    安装脚手架 . 安装构件工具 npm i wepy-cli -g .创建项目 wepy new 项目名 .实时编译 wepy build --watch 或 npm run dev .使用微信开发者工 ...

  7. Flex 项目属性:flex 布局示例

    flex属性: flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto.后两个属性可选. 该属性有两个快捷值:auto (1 1 auto ...

  8. git pull遇到错误:error: Your local changes to the following files would be overwritten by merge:

    方法1:如果你想保留刚才本地修改的代码,并把git服务器上的代码pull到本地(本地刚才修改的代码将会被暂时封存起来) git stash git pull origin master git sta ...

  9. angular 过滤器(日期转换,时间转换,数据转换等)

    (function() { 'use strict'; /** * myApp Module * * Description */ angular.module('myApp') .filter('i ...

  10. CSS单位【记录】

    1.长度 2.角度 3.时间 4.分辨率 5.颜色 6.函数 7.生成内容 8.图像 9.数字 1.长度 <length>:数字和单位之间没有空格,0之后的长度单位是可选的 相对长度单位 ...