【DRF】模型序列化器使用(5)

如果我们想要使⽤序列化器对应的是Django的模型类,DRF为我们提供了ModelSerializer模型类序列化器来帮助我们快速创建⼀个Serializer类。

ModelSerializer与常规的Serializer相同,但提供了:
基于模型类⾃动⽣成⼀系列字段
基于模型类⾃动为Serializer⽣成validators,⽐如unique_together 包含默认的create()和update()的实现

一、定义了ModelSerializer类

1、__all__

from rest_framework import serializers
from app2.models import *

class NewsChannelSerializer(serializers.ModelSerialzer):
	class Meta:
		model=NewsChannel
		fields='__all__'

测试结果

>>> from app2.serializers1 import *
>>> serializer=NewsChannelSerializer()
>>> serializer
NewsChannelSerializer():
    id = IntegerField(label='ID', read_only=True)
    name = CharField(label='频道名称', max_length=30, validators=[<UniqueValidator(queryset=NewsChannel.objects.all())>])
    url = CharField(allow_blank=True, allow_null=True, label='频道页面链接', max_length=50, required=False)

在这里插入图片描述

2、指定字段

1、model:指明参照那个模型类

2、fields指定模型类中哪些字段需要自动生成序列化器字段

  • 如果指定为__all__,那么模型类中所有的字段需要自动转化为序列化器字段
  • 如果将特定的字段转化为序列化器字段,用元组表示
    fields=(‘id’,‘name’,‘leader’,‘interfaces_set’,‘token’)
  • exclude指定模型类中哪些字段不需要设置为序列化器字段,其他的字段需要转化
    exclude=(‘create_time’,‘update_time’)

3、显示指明字段

from rest_framework import serializers
from app2.models import *

class NewsChannelSerializer(serializers.ModelSerializer):
    class Meta:
        model=NewsChannel
        fields=['id','name']

测试结果

>>> from app2.serializers1 import *
>>> from app2.models import *
>>> serializer=NewsChannelSerializer()
>>> serializer
NewsChannelSerializer():
    id = IntegerField(label='ID', read_only=True)
    name = CharField(label='频道名称', max_length=30, validators=[<UniqueValidator(queryset=NewsChannel.objects.all())>])

4、exclude

from rest_framework import serializers
from app2.models import *

class NewsChannelSerializer(serializers.ModelSerializer):
    class Meta:
        model=NewsChannel
        exclude=['id']

测试结果

>>> from app2.serializers1 import *
>>> serializer=NewsChannelSerializer()
>>> serializer
NewsChannelSerializer():
    name = CharField(label='频道名称', max_length=30, validators=[<UniqueValidator(queryset=NewsChannel.objects.all())>])
    url = CharField(allow_blank=True, allow_null=True, label='频道页面链接', max_length=50, required=False)

5、指明只读字段

可以通过read_only_fields指明只读字段,即仅⽤于序列化输出的字段

from rest_framework import serializers
from app2.models import *

class NewsChannelSerializer(serializers.ModelSerializer):
    class Meta:
        model=NewsChannel
        fields='__all__'
        read_only_fields=['id','url']

测试结果:

>>> from app2.serializers1 import *
>>> serializer=NewsChannelSerializer()
>>> serializer
NewsChannelSerializer():
    id = IntegerField(label='ID', read_only=True)
    name = CharField(label='频道名称', max_length=30, validators=[<UniqueValidator(queryset=NewsChannel.objects.all())>])
    url = CharField(allow_null=True, label='频道页面链接', read_only=True)

在这里插入图片描述

6、添加额外参数

我们可以使⽤extra_kwargs参数为ModelSerializer添加或修改原有的选项参数

from rest_framework import serializers
from app2.models import *

class NewsChannelSerializer(serializers.ModelSerializer):
    class Meta:
        model=NewsChannel
        fields='__all__'
        extra_kwargs={
            'url':{'max_length':60,'required':True}
        }

测试结果:

>>> from app2.serializers1 import *
>>> serializer=NewsChannelSerializer()
>>> serializer
NewsChannelSerializer():
    id = IntegerField(label='ID', read_only=True)
    name = CharField(label='频道名称', max_length=30, validators=[<UniqueValidator(queryset=NewsChannel.objects.all())>])
    url = CharField(allow_blank=True, allow_null=True, label='频道页面链接', max_length=60, required=True)

在这里插入图片描述

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
DRFDjango Rest Framework)是一种用于构建Web API的强大框架,它提供了丰富的功能和工具来简化API的开发过程。在使用DRF时,我们经常需要定义视图和序列化以及它们之间的关系来处理不同的请求和操作。 DRF的请求处理基于视图的操作方法,它们分别对应于HTTP方法,例如GET,POST,PUT,PATCH和DELETE。这些操作方法在视图中以函数的形式定义,并且通过装饰或路由来映射到相应的URL。 序列化DRF的一个核心概念,它提供了一种简单而灵活的方式,将数据对象转换为可以被序列化和反序列化的格式,通常是JSON或XML。序列化可以定义在视图中,也可以单独定义为一个类,然后在视图中使用。 在DRF中,我们可以通过定义不同的序列化类来处理不同的操作。序列化类可以继承自DRF提供的Serializer类或ModelSerializer类,后者自动为我们根据模型生成序列化字段。 使用序列化,我们可以在视图中方便地对请求进行验证、数据转换和结果序列化等操作。在视图的操作方法中,我们可以通过调用序列化的不同方法来进行这些操作。 例如,我们可以使用序列化的`is_valid()`方法来验证请求的数据是否有效。我们还可以使用`save()`方法来保存数据,或者使用`data`属性来获取序列化后的数据。此外,我们还可以通过调用`serializer_class()`方法来获取当前视图使用序列化类。 总之,DRF的action序列化提供了一种方便而强大的方式来处理API的请求和操作。通过定义视图和序列化,并将它们联系起来,我们可以在开发API时更加高效和灵活。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

敲代码敲到头发茂密

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值