DRF:使用巢狀序列化器進行簡單外鍵分配
在Django REST Framework 中,標準ModelSerializer 允許透過以下方式分配或修改外鍵模型關係:將ID 作為整數POST。然而,從嵌套序列化器中提取此行為可能是一個挑戰。
最簡單的巢狀序列化器方法
DRF 本身並沒有提供此功能,需要自訂序列化器欄位:
from rest_framework import serializers class RelatedFieldAlternative(serializers.PrimaryKeyRelatedField): def __init__(self, **kwargs): # Serializer for this field self.serializer = kwargs.pop('serializer', None) if self.serializer is not None and not issubclass(self.serializer, serializers.Serializer): raise TypeError('"serializer" is not a valid serializer class') super().__init__(**kwargs) def use_pk_only_optimization(self): # Avoid using PK optimization if a serializer is provided return False if self.serializer else True def to_representation(self, instance): # Use provided serializer or default representation if self.serializer: return self.serializer(instance, context=self.context).data return super().to_representation(instance)
在您的父序列化器中,將此新欄位用作如下所示:
class ParentSerializer(ModelSerializer): child = RelatedFieldAlternative(queryset=Child.objects.all(), serializer=ChildSerializer) class Meta: model = Parent fields = '__all__'
透過這種通用方法,您可以輕鬆處理具有此功能的多個序列化器。
重寫to_representation() 的方法
或者,重寫父序列化器的to_representation() 方法也可以實現此目的目標:
class ParentSerializer(ModelSerializer): def to_representation(self, instance): response = super().to_representation(instance) response['child'] = ChildSerializer(instance.child).data return response
此方法需要定義不同的欄位用於建立和讀取,這可能不太理想。
以上是如何使用 Django REST Framework 在巢狀序列化器中指派外鍵?的詳細內容。更多資訊請關注PHP中文網其他相關文章!