解-1:在一个Model1
的SerializerMethodField()
在该方法中使用Model2Serializer
,我们在Model1Serializer
限定model2_data
SerializerMethodField()
字段。在那里,我们将首先使用当前的Model1
对象获取所有的Model2
对象。然后我们用many=True
参数初始化Model2Serializer
并通过所有获得的Model2
实例。要返回Model2
对象的序列化表示形式,我们访问.data
属性。
class Model1Serializer(serializers.ModelSerializer):
model2_data = serializers.SerializerMethodField() # define separate field
class Meta:
model = Model1
fields = [.., 'model2_data']
def get_model2_data(self, obj):
# here write the logic to get the 'Model2' objects using 'obj'
# initialize the 'Model2Serializer'
model2_serializer = Model2Serializer(model2_objs, many=True)
# return the serialized representation of 'Model2' objs
return model2_serializer.data
解决方案2:覆盖retrieve
方法
另一种选择是覆盖retrieve
方法并添加model2_data
您的回复与原来的响应一起。
class MyView(generics.RetrieveAPIView):
serializer_class = Model1Serializer
def retrieve(self, request, *args, **kwargs):
instance = self.get_object()
serializer = self.get_serializer(instance)
# get the original serialized data
serialized_data = serializer.data
# get the 'Model2' objects using 'serializer.instance'
model2_serializer = Model2Serializer(model2_objs, many=True)
model2_data = model2_serializer.data
# add the serialized representation of `Model2` objs
serialized_data['model2_data'] = model2_data
return Response(serialized_data)
PS:我知道这些解决方案是不干净。如果这两个模型相关,我们可以用更清晰的方式来解决这个问题。
谢谢!我实现了第一个选项,似乎这就是我正在寻找的。 – napilnik