day86
视图组件
基于以往我们所用的视图函数,我们发现其中冗余的代码比较多,今天就来对其进行封装,争取做一个代码洁癖者
原来我们的视图函数:
class Book(APIView):
def get(self, request):
book = models.Books.objects.all()
book_ser = Ser.Books(book, many=True)
return JsonResponse(book_ser.data, safe=False) def post(self, request):
new_book = Ser.Books(data=request.data)
if new_book.is_valid():
new_book.save()
return JsonResponse(new_book.data)
else:
return JsonResponse(new_book.errors) class BookDetail(APIView):
def get(self, request, pk):
book = models.Books.objects.filter(pk=pk).first()
book_ser = Ser.Books(book, many=False)
return JsonResponse(book_ser.data, safe=False) def put(self, request,pk):
book = models.Books.objects.filter(pk=pk).first()
new_book = Ser.Books(data=request.data,instance=book)
if new_book.is_valid():
new_book.save()
return JsonResponse(new_book.data)
else:
return JsonResponse(new_book.errors)
手动一层封装:
创建了List和Create辅助类,节省了代码
class List:
def list(self, request):
queryset = self.query
info = self.serializers(queryset, many=True)
return JsonResponse(info.data, safe=False) class Create:
def create(self, request):
new = self.serializers(data=request.data)
if new.is_valid():
new.save()
return JsonResponse(new.data, safe=False)
else:
return JsonResponse(new.errors) class Book(APIView, List, Create):
query = models.Books.objects.all()
serializers = Ser.Books def get(self, request):
return self.list(request) def post(self, request):
return self.create(request) class Publish(APIView,List,Create):
query = models.Publish.objects.all()
serializers = Ser.Publish def get(self, request):
return self.list(request) def post(self, request):
return self.create(request)
使用drf自带的二层封装:
说明:
'''
CreateModelMixin: 增加
DestroyModelMixin:删
UpdateModelMixin:改
ListModelMixin:查全部
RetrieveModelMixin:查一条
'''
from rest_framework.generics import GenericAPIView
from rest_framework.mixins import ListModelMixin, CreateModelMixin, DestroyModelMixin, UpdateModelMixin, \
RetrieveModelMixin class Book(GenericAPIView, ListModelMixin, CreateModelMixin):
queryset = models.Books.objects.all()
serializer_class = Ser.Books def get(self, request):
return self.list(request) def post(self, request):
return self.create(request) class Publish(GenericAPIView, ListModelMixin, CreateModelMixin):
queryset = models.Publish.objects.all()
serializer_class = Ser.Publish def get(self, request):
return self.list(request) def post(self, request):
return self.create(request) class BookDetail(GenericAPIView, RetrieveModelMixin, DestroyModelMixin, UpdateModelMixin):
queryset = models.Books.objects.all()
serializer_class = Ser.Books def get(self, request, pk):
return self.retrieve(request, pk) def put(self, request, pk):
return self.update(request, pk) def delete(self, request, pk):
return self.destroy(request, pk)
第三层封装
drf中自己写了一个类继承了封装的类里面写了get、post等方法
from rest_framework.generics import RetrieveDestroyAPIView, ListCreateAPIView # class Book(GenericAPIView, ListModelMixin, CreateModelMixin):
class Book(ListCreateAPIView):
queryset = models.Books.objects.all()
serializer_class = Ser.Books # class BookDetail(GenericAPIView, RetrieveModelMixin, DestroyModelMixin, UpdateModelMixin):
class BookDetail(RetrieveDestroyAPIView):
queryset = models.Books.objects.all()
serializer_class = Ser.Books
最终的封装(不建议使用)
说明:
'''
终极封装是因为这个类继承了CreateModelMixin,RetrieveModelMixin,UpdateModelMixin,DestroyModelMixin,ListModelMixin,GenericViewSet):
注:在路由中配置时需要传递key:value对应的方法参数,保证对应的方法有对应的参数
{'get': 'retrieve', 'put': 'update', 'delete': 'destroy'}
'''
from rest_framework.viewsets import ModelViewSet
from rest_framework.renderers import JSONOpenAPIRenderer, BrowsableAPIRenderer, HTMLFormRenderer class Book(ModelViewSet):
# renderer_classes = [JSONOpenAPIRenderer, BrowsableAPIRenderer, HTMLFormRenderer]
queryset = models.Books.objects.all()
serializer_class = Ser.Books class Publish(ModelViewSet):
queryset = models.Publish.objects.all()
serializer_class = Ser.Publish
魔法方法(重点)
# 建议用魔法类ViewSetMixin
from rest_framework.viewsets import ViewSetMixin

day86的更多相关文章
- 问题在哪?动态菜单条-------Day86
今天做了一个动态菜单条,先上图片,简单说一下我想实现的效果: 就是以下这个地方,随着鼠标指到哪,它就划到哪,并有一个惯性的幅度,并且滑动距离越远,停住的时候惯性越大,摆动幅度越大,这就是我大概想实现的 ...
- python 全栈开发,Day86(上传文件,上传头像,CBV,python读写Excel,虚拟环境virtualenv)
一.上传文件 上传一个图片 使用input type="file",来上传一个文件.注意:form表单必须添加属性enctype="multipart/form-data ...
- day--86(MongoDB数据库)
mongodb数据库基本操作指令 ps::mongodb中的 文档,集合的概念(和mysql中的表对比理解): 集合(mongodb)--相当于mysql中的表 文档(mongodb)--相当于mys ...
- day86:luffy:前端发送请求生成订单&结算页面优惠劵的实现
目录 1.前端发送请求生成订单 1.前端点击支付按钮生成订单 2.结算成功之后应该清除结算页面的数据 3.后端计算结算页面总原价格和总的真实价格并存到数据库订单表中 2.优惠劵 1.准备工作 2.前端 ...
- 老男孩Python高级全栈开发工程师三期完整无加密带课件(共104天)
点击了解更多Python课程>>> 老男孩Python高级全栈开发工程师三期完整无加密带课件(共104天) 课程大纲 1.这一期比之前的Python培新课程增加了很多干货:Linux ...
- 国内某Python大神自创完整版,系统性学习Python
很多小伙伴纠结于这个一百天的时间,我觉得完全没有必要,也违背了我最初放这个大纲上来的初衷,我是觉得这个学习大纲还不错,自学按照这个来也能相对系统的学习知识,而不是零散细碎的知识最后无法整合,每个人的基 ...
- 22期老男孩Ptython全栈架构师视频教程
老男孩Ptython全栈架构师视频教程 Python最新整理完整版22期视频教程 超60G课程容量<ignore_js_op> <ignore_js_op> <ignor ...
随机推荐
- PHP与.Net的区别(一)接口
一.关于接口成员 PHP的接口成员只能包括两种: 1.函数签名 2.常量 .Net的接口成员只能包括三种: 1.函数签名 2.属性(注意:是属性,不是字段) 3.事件 4.索引器(也叫有参属性)
- JavaScript按纯数字排序
直接上代码: var arr=[ {name:"张散步",age:"23",sports:"篮球",number:"23112 ...
- 使用apksigner对apk进行v2签名
最近进行三方安全测试,剩最后一个问题: 原因是我用360加固宝之后,又用了360Signer对apk进行二次签名,而360Signer是用v1方式对apk进行签名的,所以安全检测还是不通过. 下面给出 ...
- Python使用map,reduce高阶函数模拟实现Spark的reduceByKey算子功能
# 使用默认的高阶函数map和reduce import randomdef map_function(arg): # 生成测试数据 return (arg,1) list_map = list(m ...
- C# 异步编程3 TPL Task 异步程序开发
.Net在Framework4.0中增加了任务并行库,对开发人员来说利用多核多线程CPU环境变得更加简单,TPL正符合我们本系列的技术需求.因TPL涉及内容较多,且本系列文章为异步程序开发,所以本文并 ...
- EF Core扩展工具记录
Microsoft.EntityFrameworkCore.AutoHistory Microsoft.EntityFrameworkCore 的一个插件,支持自动记录数据更改历史记录. GitHub ...
- Python实例---模拟微信网页登录(day3)
第四步: 扫码成功后获取最近联系人信息---day3代码 settings.py """ Django settings for weixin project. Gene ...
- Django框架的使用教程--环境的搭建和项目的创建[一]
Django环境的搭建 Django 常用的命令 # 创建一个名为Django_test子应用 python manage.py startapp Django_test # 生成迁移文件 pytho ...
- MATLAB用二分法、不动点迭代法及Newton迭代(切线)法求非线性方程的根
MATLAB用二分法.不动点迭代法及Newton迭代(切线)法求非线性方程的根 作者:凯鲁嘎吉 - 博客园http://www.cnblogs.com/kailugaji/ 一.实验原理 二.实验步骤 ...
- 【 nginx 】怎么安装nginx
一,下载地址:http://nginx.org/en/download.html 二,下载完成之后,是一个安装包,解压之后就能直接使用 三,点击进去我们刚刚解压好的nginx的安装包,打开nginx. ...