1. [
  1. 课程介绍
  2. ](_index_)
    1. [
  1. 引入DjangoRESTframework
  2. ](c01-introducetodrf_index)
  3. -
  4. [
  5. Web应用模式
  6. ](c01-introducetodrf_separatedfrontendandbackend)
    1. [
  1. 认识RESTful
  2. ](c01-introducetodrf_introducetorest)
    1. [
  1. RESTful设计方法
  2. ](c01-introducetodrf_howtodesignrest)
    1. [
  1. 使用Django开发REST接口
  2. ](c01-introducetodrf_developrestapiwithdjango)
    1. [
  1. 明确REST接口开发的核心任务
  2. ](c01-introducetodrf_coretasktodeveloprestapi)
    1. [
  1. DjangoRESTframework简介
  2. ](c01-introducetodrf_aboutdrf)
    1. [
  1. DRF工程搭建
  2. ](c02-drfproject_index)
  3. -
  4. [
  5. 环境安装与配置
  6. ](c02-drfproject_installandconfig)
    1. [
  1. 见识DRF的魅力
  2. ](c02-drfproject_thefirstdrfprogram)
    1. [
  1. Serializer序列化器
  2. ](c03-serializer_index)
  3. -
  4. [
  5. 定义Serializer
  6. ](c03-serializer_declaring)
    1. [
  1. 序列化使用
  2. ](c03-serializer_serializing)
    1. [
  1. 反序列化使用
  2. ](c03-serializer_deserializing)
    1. [
  1. 模型类序列化器ModelSerializer
  2. ](c03-serializer_modelserializer)
    1. [
  1. 视图
  2. ](c04-view_index)
  3. -
  4. [
  5. RequestResponse
  6. ](c04-view_requestandresponse)
    1. [
  1. 视图概览
  2. ](c04-view_view)
    1. [
  1. 视图说明
  2. ](c04-view_viewintroduction)
    1. [
  1. 视图集ViewSet
  2. ](c04-view_viewset)
    1. [
  1. 路由Router
  2. ](c04-view_routers)
    1. [
  1. 其他功能
  2. ](c05-components_index)
  3. -
  4. [
  5. 认证
  6. ](c05-components_authentication)
    1. [
  1. 权限
  2. ](c05-components_permissions)
    1. [
  1. 限流
  2. ](c05-components_throttling)
    1. [
  1. 过滤
  2. ](c05-components_filtering)
    1. [
  1. 排序
  2. ](c05-components_ordering)
    1. [
  1. 分页
  2. ](c05-components_pagination)
    1. [
  1. 版本
  2. ](c05-components_versioning)
    1. [
  1. 异常处理
  2. ](c05-components_exceptions)
    1. [
  1. 自动生成接口文档
  2. ](c05-components_documents)
    1. [
    2. Published with GitBook
    3. ](https://www.gitbook.com)

课程介绍

模型类序列化器ModelSerializer

如果我们想要使用序列化器对应的是Django的模型类,DRF为我们提供了ModelSerializer模型类序列化器来帮助我们快速创建一个Serializer类。
ModelSerializer与常规的Serializer相同,但提供了:

  • 基于模型类自动生成一系列字段
  • 基于模型类自动为Serializer生成validators,比如unique_together
  • 包含默认的create()和update()的实现

    1. 定义

    比如我们创建一个BookInfoSerializer ``` class BookInfoSerializer(serializers.ModelSerializer): “””图书数据序列化器””” class Meta:
    1. model = BookInfo
    2. fields = '__all__'
  1. - model 指明参照哪个模型类
  2. - fields 指明为模型类的哪些字段生成
  3. 我们可以在python manage.py shell中查看自动生成的BookInfoSerializer的具体实现

from booktest.serializers import BookInfoSerializer serializer = BookInfoSerializer() serializer BookInfoSerializer(): id = IntegerField(label=’ID’, read_only=True) btitle = CharField(label=’名称’, max_length=20) bpub_date = DateField(allow_null=True, label=’发布日期’, required=False) bread = IntegerField(label=’阅读量’, max_value=2147483647, min_value=-2147483648, required=False) bcomment = IntegerField(label=’评论量’, max_value=2147483647, min_value=-2147483648, required=False) image = ImageField(allow_null=True, label=’图片’, max_length=100, required=False)

  1. ## 2. 指定字段
  2. 1) 使用**fields**来明确字段,`__all__`表名包含所有字段,也可以写明具体哪些字段,如

class BookInfoSerializer(serializers.ModelSerializer): “””图书数据序列化器””” class Meta: model = BookInfo fields = (‘id’, ‘btitle’, ‘bpub_date’)

  1. 2) 使用**exclude**可以明确排除掉哪些字段

class BookInfoSerializer(serializers.ModelSerializer): “””图书数据序列化器””” class Meta: model = BookInfo exclude = (‘image’,)

  1. 3) 默认ModelSerializer使用主键作为关联字段,但是我们可以使用**depth**来简单的生成嵌套表示,depth应该是整数,表明嵌套的层级数量。如:

class HeroInfoSerializer2(serializers.ModelSerializer): class Meta: model = HeroInfo fields = ‘all‘ depth = 1

  1. 形成的序列化器如下:

HeroInfoSerializer(): id = IntegerField(label=’ID’, read_only=True) hname = CharField(label=’名称’, max_length=20) hgender = ChoiceField(choices=((0, ‘male’), (1, ‘female’)), label=’性别’, required=False, validators=[, ]) hcomment = CharField(allow_null=True, label=’描述信息’, max_length=200, required=False) hbook = NestedSerializer(read_only=True): id = IntegerField(label=’ID’, read_only=True) btitle = CharField(label=’名称’, max_length=20) bpub_date = DateField(allow_null=True, label=’发布日期’, required=False) bread = IntegerField(label=’阅读量’, max_value=2147483647, min_value=-2147483648, required=False) bcomment = IntegerField(label=’评论量’, max_value=2147483647, min_value=-2147483648, required=False) image = ImageField(allow_null=True, label=’图片’, max_length=100, required=False)

  1. 4) 显示指明字段,如:

class HeroInfoSerializer(serializers.ModelSerializer): hbook = BookInfoSerializer()

  1. class Meta:
  2. model = HeroInfo
  3. fields = ('id', 'hname', 'hgender', 'hcomment', 'hbook')
  1. 5) 指明只读字段<br />可以通过**read_only_fields**指明只读字段,即仅用于序列化输出的字段

class BookInfoSerializer(serializers.ModelSerializer): “””图书数据序列化器””” class Meta: model = BookInfo fields = (‘id’, ‘btitle’, ‘bpub_date’, ‘bread’, ‘bcomment’) read_only_fields = (‘id’, ‘bread’, ‘bcomment’)

  1. ## 3. 添加额外参数
  2. 我们可以使用**extra_kwargs**参数为ModelSerializer添加或修改原有的选项参数

class BookInfoSerializer(serializers.ModelSerializer): “””图书数据序列化器””” class Meta: model = BookInfo fields = (‘id’, ‘btitle’, ‘bpub_date’, ‘bread’, ‘bcomment’) extra_kwargs = { ‘bread’: {‘min_value’: 0, ‘required’: True}, ‘bcomment’: {‘min_value’: 0, ‘required’: True}, }

BookInfoSerializer():

id = IntegerField(label=’ID’, read_only=True)

btitle = CharField(label=’名称’, max_length=20)

bpub_date = DateField(allow_null=True, label=’发布日期’, required=False)

bread = IntegerField(label=’阅读量’, max_value=2147483647, min_value=0, required=True)

bcomment = IntegerField(label=’评论量’, max_value=2147483647, min_value=0, required=True)

```