前言

我们上篇文章使用到了Serializer类,可能有小伙伴说太过复杂,那么本篇就为大家带来更加简便的序列化类ModelSerializer

ModelSerializer

先来看下ModelSerializer的代码结构如下:



可以看到ModelSerializer是继承自Serializer,官方是这么介绍到的

ModelSerializer只是一个常规的Serializer,只是做了以下事情

  • 将自动填充一组默认字段
  • 将自动填充一组默认验证程序
  • 提供了默认的.create().update()实现

我们将之前的Serializer类现在用ModelSerializer来实现

class StudentModelSerializer(serializers.ModelSerializer):
class Meta:
model = Student
fields = ['id', 'name', 'age', 'sex']

默认情况下,所有的模型的字段都将映射到序列化器上相应的字段。

如果你希望在模型序列化器中使用默认字段的一部分,你可以使用fieldsexclude选项来执行此操作

  • fields:需要哪些模型字段
  • exclude:排除哪些模型字段

官方强烈建议你使用fields属性显式的设置要序列化的字段。这样就不太可能因为你修改了模型而无意中暴露了数据。

如果我们需要使用模型的全部字段,则可以将fields属性设置成'__all__'

默认情况下,fields里的字段既参加序列化也参加反序列化,如果我们想某个字段只序列化或反序列化可以定义extra_kwargs字段,代码如下:

class StudentModelSerializer(serializers.ModelSerializer):
# classes = ClassesModelSerializer(read_only=True)
class Meta:
model = Student
fields = ['id', 'name', 'age', 'sex', 'password']
extra_kwargs = {
"password": {
"write_only": True
},
"id": {
"read_only": False
}
}

上面代码如果不写extra_kwargs,那么password默认参加序列化和反序列化,那么密码就会返回给前端了,这里我们定义了extra_kwargs字段,在字段中设置了password只能反序列化,那么用户只能提交密码,而后台不会返回密码给前台

当然,extra_kwargs也可以自定义错误信息,如果业务有需要,可以查看官方文档

指定嵌套序列化

上面我们都是单模型的序列化,但是实际业务中我们不会这么简单,一定会遇到关系模型的序列化,下面我们来讲解关系模型的序列化

首先我们看一下models模型内容:

class Classes(models.Model):
name = models.CharField(max_length=20, verbose_name="班级名") class Meta:
db_table = "classes" class Student(models.Model): SEX_CHOICES = (
(1,'男'),
(2, '女')
) name = models.CharField(max_length=20, verbose_name='姓名')
age = models.IntegerField(null=True, blank=True, verbose_name='年龄')
sex = models.IntegerField(choices=SEX_CHOICES, default=1, verbose_name='性别')
classes = models.ForeignKey(Classes, on_delete=models.SET_NULL, verbose_name="班级", null=True, related_name='students')
class Meta:
db_table = "student"

我们定义了Student学生类,里面定义了一个外键classes关联Classes,一个班级中可以有多个学生,而一个学生只能属于一个班级,典型的一对多的关系,接下来我们看序列化函数

class ClassesModelSerializer(serializers.ModelSerializer):
class Meta:
model = Classes
fields = ['id', 'name', 'students'] class StudentModelSerializer(serializers.ModelSerializer):
classes = ClassesModelSerializer(read_only=True)
class Meta:
model = Student
fields = ['id', 'name', 'age', 'sex', 'classes']

我们在StudentModelSerializer中增加了一个额外的字段classes,并将字段设置为只读,一般外键只做序列化,并且在fields列表中添加了该字段。

注意:我们在创建外键模型时,必须在外键中设置related_name,如果没设置,序列化时不会返回关联的外键内容

接下来我们访问http://127.0.0.1:8000/drf/student/,会看到返回的学生表中包含了班级表的内容,如下

{
"id": 1,
"name": "jkc",
"age": 18,
"sex": 1,
"classes": {
"id": 1,
"name": "班级1",
"students": [
1,
15,
18
]
}
},

最新文章

  1. 树莓派3B远程VNC的设置(包括开机启动)
  2. linux无线配置
  3. jquery Ajax获取本地json 以及xml文件
  4. mysql 将列值转变为列的方法(转)
  5. css小记(3)
  6. 关于动态生成dom绑定事件失效的原因
  7. Team Foundation Server简介
  8. LCA(RMQ)
  9. js设置控件的隐藏与显示的两种方法
  10. (原创)LINUX_UNIX设计思想-读书笔记
  11. Unity3D之UGUI学习笔记(三):EventSystem
  12. function(a)
  13. ARM 汇编器对C的扩展
  14. RTKLIB编译及RTCM数据读取样例
  15. 如何在HTTP头中隐藏PHP版本号
  16. 小白的Python之路 day1
  17. SpringAop注解实现日志的存储
  18. 关于docker 意外停止,重新快速启动措施
  19. Papers | 超分辨 + 深度学习(未完待续)
  20. ubuntu_virtualenv

热门文章

  1. 1022 Digital Library
  2. 分享几个网址二维码生成api
  3. 本地使用apache设置绑定多个域名
  4. 【转】在CentOS 8 / RHEL 8上配置主/从BIND DNS服务器
  5. IDAPython类库---idc.py的源码
  6. Python模块化编程
  7. 从零开始搞监控系统(1)——SDK
  8. 矩阵旋转-Eigen应用(QTCreator编辑器)
  9. FFmpeg应用实践之命令查询
  10. vue2.0与3.0响应式原理机制