Django REST framework 中 3 种类视图的对比

简介:

相较于使用基于方法(function based)的视图,我们更加倾向使用基于类(class based)的视图。接

下来,你将看到这是一个强大的模式,是我们能够重用公共的功能,并且,帮我们减少重复的造轮子。

 我们现在开始了。首先,重写根视图(root view),变成基于类的视图。所涉及的,只是对 views.py 文件的一点重构。


使用基于 APIView 类的视图

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
from  testapps.models  import  Testapp
from  testapps.serializers  import  TestappSerializer
from  django.http  import  Http404
from  rest_framework.views  import  APIView
from  rest_framework.response  import  Response
from  rest_framework  import  status
 
class  TestappList(APIView):
"""
列出所有代码片段(testapps), 或者新建一个代码片段(testapp).
"""
     def  get( self , request,  format = None ):
         testapps  =  Testapp.objects. all ()
         serializer  =  TestappSerializer(testapps, many = True )
         return  Response(serializer.data)
 
     def  post( self , request,  format = None ):
         serializer  =  TestappSerializer(data = request.data)
         if  serializer.is_valid():
             serializer.save()
             return  Response(serializer.data, status = status.HTTP_201_CREATED)
         return  Response(serializer.errors, status = status.HTTP_400_BAD_REQUEST)


至此为止,一切顺利。看起来,跟基于方法的差别不大,但我们将各个 HTTP 请求方法之间,做了更好的分离。接着,我们将同样的更改我们,处理片段详细的视图,继续我们的  views.py  文件:

class TestappDetail(APIView):

至此为止,一切顺利。看起来,跟基于方法的差别不大,但我们将各个 HTTP 请求方法之间,做了更

好的分离。接着,我们将同样的更改我们,处理片段详细的视图,继续我们的  views.py  文件:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
class  TestappDetail(APIView):
 
"""
读取, 更新 or 删除一个代码片段(testapp)实例(instance).
"""
     def  get_object( self , pk):
         try :
             return  Testapp.objects.get(pk = pk)
         except  Testapp.DoesNotExist:
             raise  Http404
 
     def  get( self , request, pk,  format = None ):
         testapp  =  self .get_object(pk)
         serializer  =  TestappSerializer(testapp)
         return  Response(serializer.data)
 
     def  put( self , request, pk,  format = None ):
         testapp  =  self .get_object(pk)
         serializer  =  TestappSerializer(testapp, data = request.data)
         if  serializer.is_valid():
             serializer.save()
             return  Response(serializer.data)
         return  Response(serializer.errors, status = status.HTTP_400_BAD_REQUEST)
 
     def  delete( self , request, pk,  format = None ):
         testapp  =  self .get_object(pk)
         testapp.delete()
         return  Response(status = status.HTTP_204_NO_CONTENT)


看起来不错。但还是跟基于方法的视图,差别不多。


我们也需要重构 urls.py文件,因为我们现在使用的是基于类的视图。


1
2
3
4
5
6
7
8
9
10
from  django.conf.urls  import  url
from  rest_framework.urlpatterns  import  format_suffix_patterns
from  testapp  import  views
 
urlpatterns  =  [
     url(r '^testapp/$' , views.TestappList.as_view()),
     url(r '^testapp/(?P<pk>[0-9]+)/$' , views.TestappDetail.as_view()),
]
 
urlpatterns  =  format_suffix_patterns(urlpatterns)


好,搞定。如果你跑起开发者服务器,应该跟之前的效果是一样的。


使用 Mixins 类的视图


使用类视图的一大好处是,我们可以很容易地,组成可重复使用的行为。

目前为止,我们所用的增删改查操作,在我们创建的,任何支持模型的视图里,都没有太大区别。这些

通用的行为,在 REST framework的 Mixin类中,都已经实现了。

让我们看看,使用混合类,如何组建视图。下面同样是我们的 views.py 模块:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
from  testapp.models  import  Testapp
from  testapp.serializers  import  Testapperializer
from  rest_framework  import  mixins
from  rest_framework  import  generics
 
class  TestappList(mixins.ListModelMixin,
                   mixins.CreateModelMixin,
                   generics.GenericAPIView):
     queryset  =  Testapp.objects. all ()
     serializer_class  =  Testapperializer
 
     def  get( self , request,  * args,  * * kwargs):
         return  self . list (request,  * args,  * * kwargs)
 
     def  post( self , request,  * args,  * * kwargs):
         return  self .create(request,  * args,  * * kwargs)


我们会花一些时间来审查一下,这里发生的事情。我们使用 GenericAPIView 创建了我们的视图,并且

加入了 ListModelMixin 和 CreateModelMixin 。


基本类提供了核心的功能,Mixin 类提供了 .list() 和 .create() 行为。然后,我们显式地在 get 

和 post 方法里面,放入对应的行动。非常简单,但目前够用。


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class  TestappDetail(mixins.RetrieveModelMixin,
                     mixins.UpdateModelMixin,
                     mixins.DestroyModelMixin,
                     generics.GenericAPIView):
     queryset  =  Testapp.objects. all ()
     serializer_class  =  TestappSerializer
 
     def  get( self , request,  * args,  * * kwargs):
         return  self .retrieve(request,  * args,  * * kwargs)
 
     def  put( self , request,  * args,  * * kwargs):
         return  self .update(request,  * args,  * * kwargs)
 
     def  delete( self , request,  * args,  * * kwargs):
         return  self .destroy(request,  * args,  * * kwargs)


非常的类似。我们使用了 GenericAPIView 类提供了核心功能,而 Mixin 类提供了 .retrieve() 

,.update() 和 .destroy() 行为。


使用 Generic 类的视图


使用混 Mixin 类重新视图,相比之前,我们减少了一些代码,但我们还可以更进一步。REST framework


提供了一套已经实现了 Mixin 类的 Generic 视图,我们可以使我们的 views.py 模块,更加瘦身!


1
2
3
4
5
6
7
8
9
10
11
from  testapps.models  import  Testapp
from  testapps.serializers  import  TestappSerializer
from  rest_framework  import  generics
 
class  TestappList(generics.ListCreateAPIView):
     queryset  =  Testapp.objects. all ()
     serializer_class  =  TestappSerializer
 
class  TestappDetail(generics.RetrieveUpdateDestroyAPIView):
     queryset  =  Testapp.objects. all ()
     serializer_class  =  TestappSerializer


哇噻~这下够简洁了。代码看起来像是很厉害的,干净的,地道的 Django。




本文转自 xjtuhit 51CTO博客,原文链接:http://blog.51cto.com/51reboot/1981779
相关文章
|
4月前
|
JSON 前端开发 API
Django 后端架构开发:通用表单视图、组件对接、验证机制和组件开发
Django 后端架构开发:通用表单视图、组件对接、验证机制和组件开发
74 2
|
4月前
|
JSON 数据处理 API
Django后端架构开发:视图与模板的正确使用
Django后端架构开发:视图与模板的正确使用
50 1
|
3月前
|
数据处理 Python
Django视图:构建动态Web页面的核心技术
Django视图:构建动态Web页面的核心技术
|
4月前
|
安全 API Python
Django 如何使用视图动态输出 CSV 以及 PDF
Django 如何使用视图动态输出 CSV 以及 PDF
56 4
|
4月前
|
C++ Python
Django视图函数VS类视图:如何选择最适合你的开发方式?
【8月更文挑战第31天】本文对比了Django中的函数视图和类视图。函数视图直接处理HTTP请求和响应,灵活且易于维护,适用于简单业务逻辑;类视图基于Python类,提供更丰富的功能和更高的灵活性,适合处理复杂业务逻辑。选择哪种视图取决于具体需求,合理使用两者可帮助你构建高效且易维护的Django应用。
93 0
|
4月前
|
JSON API 数据安全/隐私保护
哇塞!Django REST framework 太逆天啦!构建 API 服务从未如此轻松,你还不来试试?
【8月更文挑战第31天】Django REST framework(DRF)是基于Django框架的高效Web API开发工具,提供序列化、视图集、路由等功能,简化API构建流程。使用DRF可轻松实现数据的序列化与反序列化,并支持权限管理和认证机制以保障API安全。安装DRF只需通过`pip install djangorestframework`命令。要创建基本项目,先安装Django并创建新应用,定义模型、序列化器及视图集,最后配置路由。测试API时,可通过Postman发送HTTP请求验证功能。无论项目大小,DRF均能提供强大支持。
49 0
|
4月前
|
Linux Shell 数据库
python Django教程 之 安装、基本命令、视图与网站
python Django教程 之 安装、基本命令、视图与网站
|
5月前
|
API 数据库 数据安全/隐私保护
Django配置api、管理系统和视图
Django配置api、管理系统和视图
133 1
|
4月前
|
中间件 API 网络架构
Django后端架构开发:从匿名用户API节流到REST自定义认证
Django后端架构开发:从匿名用户API节流到REST自定义认证
51 0
|
4月前
|
测试技术 Shell 数据库
Django视图测试:构建可靠Web应用的关键步骤
Django视图测试:构建可靠Web应用的关键步骤
31 0