在我们定义的序列化类中,定义一个Meta内部类,即可通过在类内添加属性来使用ModelSerializer类自动生成一个序列化器,下面是一些常用属性:
model=Model:用来指定需要创建序列化器的模型类fields=[]: 该序列化器所需要的字段
若需要所有字段则fields = '__all__'
在外部类中如果定义一个新字段,那么该字段必须添加read_only = True属性,即代表该字段不可被写入数据库,这个功能可以用在验证码上,接收数据但不储存数据,引用官方文档上的话:
Set this to True to ensure that the field is used when serializing a representation, but is not used when creating or updating an instance during deserialization.
将此设置为 True 以确保在序列化表示时使用该字段,但在反序列化期间创建或更新实例时不使用该字段
exclude:该序列化器不需要的字段read_only_fields:设置只读字段,若设置了editable=False,AutoField或read_only=True属性的字段可以不写入该属性中extra_kwargs:用于向字段中添加额外的属性

如果该属性已声名,则可以更改,值若一致,则忽略.
更多可参考官方文档
本文深入探讨了Django的序列化器Meta类的使用,包括如何通过Meta指定模型、设置字段、排除字段、定义只读字段以及使用extra_kwargs添加额外属性。Meta类使得在创建序列化器时能更加灵活地控制模型字段的序列化过程,尤其适用于在验证数据时接收但不存储的数据场景。了解这些属性有助于提升Django应用的开发效率。

597

被折叠的 条评论
为什么被折叠?



