django rest framework 序列化组件总结

序列化组件总结

一.

序列化组件本质上为了实现前后端分离,而进行json序列化的一个组件形式,极大方便了解析数据的作用

二.

所有序列化是基于APIView 解析器实现的,通过内部的多继承关系方便实现进行数据序列化的实现

使用方式

1.基于APIView 引入  from rest_framework.views import APIView

2.返回的请求用  Response  from rest_framework.response import Response

3.开始进行创建序列化类的方式  from rest_framework import serializers

第一步 创建序列化类

创建出在返回页面显示的字段 ,一对多关系同创建普通字段一样,无需特意声明关系,但需要引入sourse=publish.city

多对多关系需要手动创建一个特定的方法

第二步 创建需要解析的数据类 继承APIview 方法

创建的方法要遵循rest请求规范

1.获取需要传递的数据

2.将数据传到序列化类中,返回一个实例化对象

3.通过返回return Response (实例化对象.data)返回给页面

优化

一.问题

在进行post 请求时,需要不断创建字段添加数据,很麻烦

这样可以优化序列化类,引用serializers.ModelSerializer

同form表单的modelform也一样,

class META:

model:

fields:

extra_ksargs: 这里添加关联字段用的 字典形式{

‘publish‘:{"write_only":true}

"authors":{"write_only":true}

}

显示的字段

publish_name = serializers.CharField(max_length=32, read_only=True, source=‘publish.name‘)publish_city = serializers.CharField(max_length=32, read_only=True, source=‘publish.city‘)

手动创建的多对多数据

视图优化

即使优化了序列化类,但是发现数据类有很多的代码冗余,于是引入

mixins: from rest_framework.mixins import (
ListModelMixin,
CreateModelMixin,
DestroyModelMixin,
UpdateModelMixin,
RetrieveModelMixin
)

继承的apivies :from rest_framework.generics import GenericAPIView

通过创建数据类引用的模块优化代码

使用:

1.引入模块

2.创建类时有两个关键字段 quertset=找到的数据  serializer_class=引用的序列化类的名字

3.返回请求的特殊方式

def get(self,request, *args, **kwargs):
return self.list(request, *args, **kwargs)
def post(self,request, *args, **kwargs):
return self.create(request, *args, **kwargs)

4.urls 这里需要特定说明 引用 (?P<pk>\d+) 来拼接

path("course/",views.BookView.as_view()),re_path("course/(?P<pk>\d+)/",views.BookFilterView.as_view())

  

优化二

但是发现依然有大量代码冗余

于是引入接口逻辑新模块

from rest_framework import generics通过
generics.ListCreateAPIView 里面的内置方法省掉了 多余的def get/post 请求方法,都被封装的里面 但是会发现在查询 全部数据以及单个数据时候,需要创建两个数据类,可不可以用一个呢

于是引出最终优化
 

优化三

引入from rest_framework.viewsets import ModelViewSet 模块

这里更强大,只需要

class BookView(ModelViewSet):    queryset = Book.objects.all()    serializer_class = BookSerializer

就足够了但是在urls 里需要特意说明,,注意 都是引用一个视图函数哟
re_path("course/$",views.BookView.as_view({    "get":"list",    "post":‘create‘,})),re_path("course/(?P<pk>\d+)/",views.BookView.as_view({    ‘get‘:‘retrieve‘,    ‘put‘:"update",    ‘delete‘:"destroy"}))

原文地址:https://www.cnblogs.com/zhangqing979797/p/10090756.html

时间: 2024-10-11 04:30:18

django rest framework 序列化组件总结的相关文章

Django Rest Framework --- 序列化组件

一.序列化组件的作用 在前后端分离开发时,前端与后端用来交互的数据的格式是一致的(数据格式为字符串的json数据),于是后端程序员在传递数据时,便要将数据封装成符合格式的数据,如果不借助方法,手动进行数据封装,会非常的浪费时间,在Django rest framework中的序列化组件帮我们解决了这个问题. 二.Django自带的序列化组件 from django.core import serializers def test(request): book_list = Book.object

Django REST framework序列化

Django REST framework序列化 开发我们的Web API的第一件事是为我们的Web API提供一种将代码片段实例序列化和反序列化为诸如json之类的表示形式的方式 models部分 from django.db import models class Book(models.Model): title = models.CharField(max_length=32) price = models.IntegerField() pub_date = models.DateFie

Django Rest framework序列化流程

目录 一 什么是序列化 二 Django REST framework配置流程之Serializer 三 Django REST framework配置流程之ModelSerializer 一 什么是序列化 序列化模型与序列化关系模型 序列化模型,顾名思义,即对 models 里的数据模型作序列化. 而序列化关系模型则是对 models 里数据模型中带有关系的如 ForeignKey, ManyToManyField 和 OneToOneField 字段作序列化. Django Rest Fra

django rest_framework Serializers 序列化组件

为什么要用序列化组件 当我们做前后端分离的项目~~我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 那么我们给前端数据的时候都要转成json格式,那就需要对我们从数据库拿到的数据进行序列化. 接下来我们看下django序列化和rest_framework序列化的对比~~ Django的序列化方法 class BooksView(View): def get(self, request): book_list = Book.objects.values("id&quo

Django REST Framework 序列化和校验 知识点

DRF序列化 Django ORM对象 --> JSON格式的数据 序列化 JSON格式的数据 --> Django ORM数据 反序列化 需要两个工具: from rest_framework.serializers import Serializer from rest_framework.serializers import MoselSerializer 类比Django中的form组件 Django form --> HTML表单 HTML表单  --> ORM数据 用法

Django REST framework 基本组件

一.序列化组件 简单使用 开发我们的Web API的第一件事是为我们的Web API提供一种将代码片段实例序列化和反序列化为诸如json之类的表示形式的方式.我们可以通过声明与Django forms非常相似的序列化器(serializers)来实现. models部分: from django.db import models # Create your models here. class Book(models.Model): title=models.CharField(max_leng

Django REST framework(序列化)

准备工作 一丶配置虚拟环境 1.安装虚拟包:pip install virtualenv 2.创建一个用于虚拟环境的目录,并进入到目录下 3.执行 python -m venv 虚拟环境名 4.执行 virtualenv 虚拟环境名 5.在目录下激活虚拟环境 windos下:source env\Scripts\activate linux下:source env/bin/activate 6.停止虚拟环境 deactivate指令或者关闭终端 二丶用于代码高亮显示pip install pyg

Django REST framework —— 权限组件源码分析

在上一篇文章中我们已经分析了认证组件源码,我们再来看看权限组件的源码,权限组件相对容易,因为只需要返回True 和False即可 代码 1 class ShoppingCarView(ViewSetMixin, APIView): 2 permission_classes = [MyPermission, ] 3 def list(self,request, *args, **kwargs): 4 """ 5 查看购物车信息 6 :param args: 7 :param k

Django Rest Framework 认证组件

'''用户认证章节''' # 用户认证章节:写一个数据接口 from django.http import JsonResponse from .utils import get_token from rest_framework.exceptions import APIException class UserView(APIView): def post(self, request): # 定义返回消息体 response = dict() # 定义需要的用户信息 fields = {"us