17

我有一种情况,我的客户试图编写一个包含 fk 列表的表示

{
languages: [1]
last_name: "Beecher"
settings: 1
state: "NY"
}

但是在阅读它时,我想要一个嵌套表示来减少往返

{
languages: [{id:1, created:2013-07-21T01:38:33.569Z, modified:2013-07-21T01:38:33.569Z, language:testing}]
last_name: "Beecher"
settings: {
created: "2013-07-20T22:04:17.998Z"
email_blog: false
email_booking_accepted_denied: false
email_booking_request: false
email_friend_joined: false
email_groups_added_network: false
email_new_review: false
email_news: false
email_upcoming_booking_remind: false
id: 1
mobile_booking_accepted_denied: false
mobile_booking_request: false
mobile_friend_joined: false
mobile_groups_added_network: false
mobile_new_review: false
mobile_upcoming_booking_remind: false
modified: "2013-07-20T22:04:18.000Z"
user: 1
}
state: "NY"
}

使用模型序列化程序和 depth=1 读取没有问题 - 但尝试写入时会出现错误“ValueError('instance should be a queryset or other iterable with many=True')”当尝试检查iter的许多相关字段时

相反,关闭深度可以让写作如我所愿,但阅读并不好。

这里有什么我完全想念的吗?看起来这应该是一个简单的改变,但我只能让一个或另一个工作

4

3 回答 3

5

感谢以前的帖子,我为此采用了类似的解决方案get_serializer_class

我还希望能够根据方法更改序列化程序类。

首先,我向视图类添加了一个属性,其中包含将请求方法映射到序列化程序类的字典。

 serializer_classes = {
     'GET': NestedSerializer,
     'POST': FlatSerializer
 }

然后,我定义了一个 mixin 以在我想要这种行为的地方使用。

class SwappableSerializerMixin(object):
    def get_serializer_class(self):
        try:
            return self.serializer_classes[self.request.method]
        except AttributeError:
            logger.debug('%(cls)s does not have the required serializer_classes'
                         'property' % {'cls': self.__class__.__name__})
            raise AttributeError
        except KeyError:
            logger.debug('request method %(method)s is not listed'
                         ' in %(cls)s serializer_classes' %
                         {'cls': self.__class__.__name__,
                          'method': self.request.method})
            # required if you don't include all the methods (option, etc) in your serializer_class
            return super(SwappableSerializerMixin, self).get_serializer_class() es
于 2014-01-24T06:16:28.007 回答
3

我有同样的问题,看起来很多其他人也有。Carlton Gibson的回答实际上将我引向了我的 hacky 解决方案。我最终使用了具有深度集的ModelSerializer,并创建了以下 mixin 以在视图中使用。

class ReadNestedWriteFlatMixin(object):
    """
    Mixin that sets the depth of the serializer to 0 (flat) for writing operations.
    For all other operations it keeps the depth specified in the serializer_class
    """
    def get_serializer_class(self, *args, **kwargs):
        serializer_class = super(ReadNestedWriteFlatMixin, self).get_serializer_class(*args, **kwargs)
        if self.request.method in ['PATCH', 'POST', 'PUT']:
            serializer_class.Meta.depth = 0
        return serializer_class
于 2013-10-23T00:37:48.900 回答
1

我想到的最简单的事情是覆盖get_serializer_class()您的 POST/PUT 视图以返回修改后的序列化程序,而不是指定深度参数并为您的字段使用PrimaryKeyRelatedField 。languages

于 2013-09-13T13:09:09.280 回答