Django REST framework的各类技巧——2.serializer

serializer只作一件事情,json化model对象,因此这一部分至关简单前端

Django REST framework的各类技巧【目录索引】数据库

写在最上面

全部的代码都是在下面的两个版原本作的django

django==1.8.8
djangorestframework==3.2.5

首先是官方文档json

讲解

拿基本的user,group为例子segmentfault

首先一个关联的modelapi

class UserProfile(TimeStampedModel):

    user = models.OneToOneField(User, unique=True, db_index=True, related_name='profile')
    name = models.CharField(blank=True, max_length=255, db_index=True)
    phone = models.CharField(default='', blank=True, max_length=64)
    nickname = models.CharField(blank=True, null=True, max_length=255, db_index=True)
    avatar = models.URLField(blank=True, max_length=255, default='')
    is_cms_user = models.BooleanField(default=False, db_index=True)
    is_cms_active = models.BooleanField(default=False, db_index=True)

    class Meta:  # pylint: disable=missing-docstring
        db_table = "auth_userprofile"

    def __unicode__(self):
        return self.name

User对应的serializeride

class GroupSerializer(serializers.ModelSerializer):

    class Meta:
        model = Group
        fields = ('id', 'name')

class UserSerializer(serializers.ModelSerializer):
    groups = GroupSerializer(many=True)
    phone = serializers.CharField(source='profile.phone', read_only=True)
    name = serializers.CharField(source='profile.name', read_only=True)
    menus = serializers.SerializerMethodField()
    is_active = serializers.BooleanField(source='profile.is_cms_active')

    def get_menus(self, user):
        return get_menus(user)

    class Meta:
        model = User
        fields = ('id', 'username', 'name', 'email', 'phone', 'groups', 'menus', 'is_active')

一个请求的responseui

{
    "id": 2,
    "username": "duoduo3369",
    "name": "",
    "email": "",
    "phone": "",
    "groups": [
        {
            "id": 1,
            "name": "sysadmin"
        },
        {
            "id": 17,
            "name": "大学2"
        }
    ],
    "menus": [
        {
            "menu": [
                {
                    "menu": [],
                    "codename": "information.announcement",
                    "name": "通知公告",
                    "order": 1
                },
                {
                    "menu": [],
                    "codename": "information.examinfo",
                    "name": "考试信息",
                    "order": 2
                }
            ]
       }
    ],
    "is_active": false
}
  • 外键直接能够引用其余的serializer,例如group,能够看到response中group是嵌套的rest

  • 外键的属性可使用source,例如phonecode

  • 不在原来model上的东西使用SerializerMethodField(或者在model上可是你要对这个值作一些特殊处理)

注意点

  • serializer能够作逻辑上的操做,然而最好不要作查询(你能够用SerializerMethodField作一些数据转换例如0变为假1变为真什么的,然而最好不要作复杂的数据库查询),这种事情能够在view上作好(注意能够用select_related减小屡次查询),由于这是每个model都要serializer一次。

  • 若是说跟前端对的修改和查询使用不一样的serializer,那么你就写两个,不但愿修改的字段加上readonly(或者放在readonly_fields里面)

serializer的逻辑很简单,想到复杂的东西再说。Done

相关文章
相关标签/搜索