在 DRF 的 CreateAPI 中创建 Django 对象后,您会得到一个创建状态 201,并且该对象使用您用来创建 Django 对象的相同序列化程序返回。
通缉:创建时:Serializer.comments = Textfield(write_only=True)
并在创建(201 状态)Serializer.comments = 评论列表
我知道通过覆盖 CreateAPIView.create 函数是可能的。
但是,我想知道是否可以使用 write_only=True
和 read_only=True
序列化器字段的属性。
现在我认为这是不可能的,因为它们都具有相同的名称。
我很想使用假 kwarg 名称做这样的事情 actual_name
:
class CreateEventSerializer(serializers.ModelSerializer):
comments_readonly = serializers.SerializerMethodField(read_only=True, actual_name='comments')
class Meta:
model = Event
fields = ('id', 'comments', 'comments_readonly')
def __init__(self, *args, **kwargs):
super(CreateEventSerializer, self).__init__(*args, **kwargs)
self.fields['comments'].write_only = True
def get_comments_readonly(self, obj):
comments = obj.comments.replace('\r', '\n')
return [x for x in comments.split('\n') if x != '']
但是这样,返回的 JSON 仍然包含键“comments_readonly”而不是想要的键“comments”。
使用最新的 DRF,3.7.1
换句话说:
是否可以创建一个基于读取和写入行为不同的序列化器字段(仅使用 1 个序列化器类)?
最佳答案
这似乎对 JSON 响应有用,但感觉有点麻烦,因为 DRF HTML 表单现在在注释文本区域字段中显示 python 列表。
class CreateEventSerializer(serializers.ModelSerializer):
class Meta:
model = Event
fields = ('id', 'comments')
def get_comments(self, obj):
comments = obj.comments.replace('\r', '\n')
return [x for x in comments.split('\n') if x != '']
def to_representation(self, instance):
data = super(CreateEventSerializer, self).to_representation(instance)
data['comments'] = self.get_comments(instance)
return data
关于django - 如何在 DRF 中使用相同名称的 read_only 和 write_only 不同的序列化程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46834177/