Django DRF - 模型视图集ModelViewSet与路由的使用

一. ModelViewSet

由提供的动作ModelViewSet类是.list(),.retrieve(),.create(),.update(),.partial_update(),和.destroy()

使用:

因为ModelViewSet扩展GenericAPIView,我们通常需要提供至少querysetserializer_class属性

from rest_framework.viewsets import ModelViewSet
from book.serializers import BookInfoModelSerializer
from book.models import BookInfo

class BookModelViewSet(ModelViewSet):

    queryset = BookInfo.objects.all()
    serializer_class = BookInfoModelSerializer

在设置路由时,我们可以如下操作

from book import views
urlpatterns = [
]

from rest_framework.routers import DefaultRouter
# 可以处理视图的路由器
router = DefaultRouter()
# 向路由器中注册视图集
router.register(r'books', views.BookModelViewSet,basename='')
#追加路由
urlpatterns += router.urls

二. 路由的介绍说明

路由Router
文档

对于视图集ViewSet,我们除了可以自己手动指明请求方式与动作action之间的对应关系外,还可以使用Routers来帮助我们快速实现路由列表信息。

REST framework提供了两个router

  • SimpleRouter
  • DefaultRouter

1. 使用方法

1) 创建router对象,并注册视图集,注册语法为

register(prefix, viewset,basename)
prefix 该视图集的路由前缀
viewset 视图集
basename路由名称的前缀

例如

from rest_framework import routers

router = routers.DefaultRouter()

router.register(r'books', BookViewSet, basename='book')

如上述代码会形成的路由如下:

^books/$    name: book-list
^books/{pk}/$   name: book-detail

2)添加路由数据

可以有两种方式:

urlpatterns = [
    ...
]
urlpatterns += router.urls

urlpatterns = [
    ...
    path('', include(router.urls))
]

DefaultRouter与SimpleRouter的区别是,DefaultRouter会多附带一个默认的API根视图,返回一个包含所有列表视图的超链接响应数据。
Django DRF - 模型视图集ModelViewSet与路由的使用_第1张图片

以上就是django DRF 模型视图集ModelViewSet的简单使用介绍,之后会在单独使用简单的demo在单独介绍。
希望该文对你有所帮助。

你可能感兴趣的:(DFR-Django,Rest,Framework框架,Django,django,python,后端)