DRF : affectation simple de clé étrangère avec des sérialiseurs imbriqués
Dans Django REST Framework, un ModelSerializer standard permet l'affectation ou la modification des relations de modèle ForeignKey via Publier un identifiant sous forme d'entier. Cependant, extraire ce comportement d'un sérialiseur imbriqué peut être un défi.
Approche de sérialiseur imbriqué la plus simple
DRF ne fournit pas intrinsèquement cette fonctionnalité, ce qui nécessite un champ de sérialiseur personnalisé. :
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)
Dans votre sérialiseur parent, utilisez ce nouveau champ comme suit :
class ParentSerializer(ModelSerializer): child = RelatedFieldAlternative(queryset=Child.objects.all(), serializer=ChildSerializer) class Meta: model = Parent fields = '__all__'
Avec cette approche générique, vous pouvez facilement gérer plusieurs sérialiseurs avec cette fonctionnalité.
Méthode pour remplacer to_representation()
Alternativement, remplacer la méthode to_representation() du sérialiseur parent permet également d'atteindre cet objectif :
class ParentSerializer(ModelSerializer): def to_representation(self, instance): response = super().to_representation(instance) response['child'] = ChildSerializer(instance.child).data return response
Cette méthode nécessite de définir différents domaines de création et de lecture, ce qui n'est peut-être pas idéal.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!