您的位置:首页 > 其它

DRF-serializers.Serializer序列化器

2020-04-22 02:47 1696 查看

模型类用例

这里设置一个Django ORM用来当作下面的测试用例

class StudentInfo(models.Model):
name = models.CharField(max_length=20, verbose_name='姓名')
birthday = models.DateField(verbose_name='生日', null=True)
money = models.IntegerField(default=0, verbose_name='现金')
image = models.ImageField(upload_to='studenttest', verbose_name='照片', null=True)

1. 手动定义一个序列化器

  • Django REST framework中的
    Serializer
    使用类来定义,须继承自
    rest_framework.serializers.Serializer
  • 注意:
    serializer
    不是只能为数据库模型类定义,也可以为非数据库模型类的数据定义.
    serializer
    是独立于数据库之外的存在
#导入父类进行继承
from rest_framework import serializers

class StudentSerializer(serializers.Serializer)
id = serializers.IntegerField(label='ID', read_only=True)
name = serializers.CharField(label='姓名', max_length=20)
birthday = serializers.DateField(label='生日', required=False)
money = serializers.IntegerField(label='现金', required=False)
image = serializers.ImageField(label='照片', required=False)

2. 序列化器的字段与选项

  • 字段
CharField: CharField(max_length=None, min_length=None, allow_blank=False, trim_whitespace=True)
IntegerField: IntegerField(max_value=None, min_value=None)
BooleanField: BooleanField()
NullBooleanField: NullBooleanField()
EmailField: EmailField(max_length=None, min_length=None, allow_blank=False)
RegexField: RegexField(regex, max_length=None, min_length=None, allow_blank=False)
SlugField: SlugField(maxlength=50, min_length=None, allow_blank=False)正则字段,验证正则模式 [a-zA-Z0-9-]+
URLField: URLField(max_length=200, min_length=None, allow_blank=False)
IPAddressField: IPAddressField(protocol='both', unpack_ipv4=False, **options)
IntegerField: IntegerField(max_value=None, min_value=None)
FloatField: FloatField(max_value=None, min_value=None)
DecimalField: DecimalField(max_digits, decimal_places, coerce_to_string=None, max_value=None, min_value=None)          max_digits: 最多位数,decimal_palces: 小数点位置
DateTimeField: DateTimeField(format=api_settings.DATETIME_FORMAT, input_formats=None)
DateField: DateField(format=api_settings.DATE_FORMAT, input_formats=None)
TimeField: TimeField(format=api_settings.TIME_FORMAT, input_formats=None)
DurationField: DurationField()
ChoiceField: ChoiceField(choices)      choices与Django的用法相同
MultipleChoiceField: MultipleChoiceField(choices)
FileField: FileField(max_length=None, allow_empty_file=False,use_url=UPLOADED_FILES_USE_URL)
ImageField: ImageField(max_length=None,allow_empty_file=False,use_url=UPLOADED_FILES_USE_URL)
ListField: ListField(child=, min_length=None, max_length=None)
DictField: DictField(child=)
  • 选项
max_length: 最大长度
min_lenght: 最小长度
allow_blank: 是否允许为空
trim_whitespace: 是否截断空白字符
max_value: 最小值
min_value: 最大值
  • 通用选项
read_only: 表明该字段仅用于序列化输出,默认False
write_only: 表明该字段仅用于反序列化输入,默认False
required: 表明该字段在反序列化时必须输入,默认True
default: 反序列化时使用的默认值
allow_null: 表明该字段是否允许传入None,默认False
validators: 该字段使用的验证器
error_messages: 包含错误编号与错误信息的字典
label: 用于HTML展示API页面时,显示的字段名称
help_text: 用于HTML展示API页面时,显示的字段帮助提示信息

3. 创建Serializer对象

Serializer
的构造方法为:

Serializer(instance=None, data=empty, **kwarg)
  • instance
    : 序列化时传入的模型类对象
  • data
    : 反序列化是需要传入的数据
  • 除了
    instance
    data
    参数外,在构造Serializer对象时,还可通过context参数额外添加数据,如
    serializer = AccountSerializer(account, context={'request': request})
    通过context参数附加的数据,可以通过Serializer对象的context属性获取
  • 点赞
  • 收藏
  • 分享
  • 文章举报
╰☆阳光のboy 发布了36 篇原创文章 · 获赞 2 · 访问量 1596 私信 关注
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: