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