对于视图集ViewSet,我们除了可以自己手动指明请求方式与动作action之间的对应关系外,还可以使用Routers来帮助我们快速实现路由信息
- path('test/', views.Test.as_view()),
-path('test/', views.Test.as_view({
'get':'send_email'})),
-自动生成路由
前提 : 必须是继承了 ViewSetMixin 类的视图+9种视图子类才可以使用路由组件快速生成路由
导入路由类 : from rest_framework.routers import SimpleRouter,DefaultRouter
实例化得到对象 : router = SimpleRouter()
注册路由 : router.register('book2',views.BookView)
把自动生成的路由加到 urlpatterns 中去 : urlpatterns += router.urls
# 查看其源码
def register(self, prefix, viewset, basename=None):
...
# prefix : 路由前缀
# viewset : 视图集
# basename : 路由别名
prefix
参数不需要加前缀router.register('book2',views.BookView) # book2 不需要加前缀
from django.contrib.auth.models import AbstractUser
class base(models.Model):
name = models.CharField(max_length=16)
price = models.IntegerField()
class Mate:
abstract = True # 声明这张表是张抽象表,不会在数据库中进行创建,只用来给别的模型类继承
class Book2(base): # 继承了base,就会有base中的字段
nid = models.AutoField(primary_key=True)
author = models.CharField(max_length=16, null=True)
publish = models.CharField(max_length=16, null=True)
abstract
:一般用于多个模型类中存在相同的字段,为了减少代码量和重复写相同的字段, 可以使用
abstract
指定一张抽象表用作继承
class BookSerializer(serializers.ModelSerializer):
class Meta:
model = models.Book2
fields = "__all__"
from rest_framework.viewsets import ModelViewSet
from mydrf.serializers import BookSerializer
class BookView(ModelViewSet):
queryset = models.Book2.objects.all()
serializer_class = BookSerializer
# 1.导入路由类
from rest_framework.routers import SimpleRouter,DefaultRouter
# 2.实例化得到对象
router = SimpleRouter()
# 3.注册路由
router.register('book2',views.BookView)
print(router.urls) # 自动生成的路由
'''
[, [^/.]+)/$' [name='book2-detail']>]
'''
urlpatterns = []
# 4.把自动生成的路由加到 urlpatterns 中去(实际上就是两个列表相加)
urlpatterns += router.urls
# 需要导入 include
from django.urls import path,include
urlpatterns = [
path(r'',include(router.urls))
]
# 或者添加前缀
urlpatterns = [
path(r'app1/',include(router.urls))
]
导入:
from rest_framework.decorators import action
class BookView(ModelViewSet):
queryset = models.Book2.objects.all()
serializer_class = BookSerializer
# 自定义的方法不会自动生成路由, 需要添加 action 装饰器
def index(self, request):
return Response('ok!')
# 不会自动生成路由
def top5(self, request):
return Response('get_5_ok!')
method
: 声明该 action 对应的请求方式, 使用列表传递# 查看其源码 :
methods = ['get'] if (methods is None) else methods
methods = [method.lower() for method in methods]
# 第一条如果没有指定该参数,默认是 "get" 方法
# 第二条表示方法可以大小写,它都会将其转换成小写
detail
: 声明该 action 的路径是否与单一资源对应,布尔值# True : 表示不是单一资源路径(可以用来匹配一条数据) :
例:127.0.0.1:8000/<pk>/[action方法名]/
# False : 表示单一的资源路径(可以匹配多条数据) :
例:127.0.0.1:8000/[action方法名]/
# 先导入 action
from rest_framework.decorators import action
class BookView(ModelViewSet):
queryset = models.Book2.objects.all()
serializer_class = BookSerializer
@action(methods=['get'],detail=False)
def index(self, request):
return Response('ok!')
@action(methods=['post'],detail=True)
def top5(self, request):
return Response('get_5_ok!')