在列表序列化程序 class 中覆盖 to_representation

Override to_representation in List serializer class

我有一个实现 BaseSerializer class 的序列化器,我在其中使用 to_representation 函数来执行如下函数调用:

class ItemSerializer(serializers.BaseSerializer):
    def to_representation(self, instance):
        ret = super().to_representation(instance)
        ret['log'] = SERVICE.log(instance.id)
        return ret

    class Meta:
        list_serializer_class = ItemListSerializer
        model = models.Item
        fields = '__all__'

我也有一个相同的 ItemListSerializer 的列表序列化程序,如下所示:

class ItemListSerializer(serializers.ListSerializer):
    def create(self, validated_data):
        items = [models.Item(**item) for item in validated_data]
        return models.Item.objects.bulk_create(items)

我想做的是覆盖 ItemSerializer 中的 to_representation 方法,以便在我想要获取整个项目列表时使用。我基本上想避免对每个项目进行函数调用,而是在出于性能原因请求项目列表时对所有项目进行批量调用。

有什么好的方法吗?我按照这些文档创建 ItemListSerializer:https://www.django-rest-framework.org/api-guide/serializers/#customizing-listserializer-behavior 但它只讨论覆盖创建和更新方法。

您可以访问 ListSerializer.to_representation

中的所有项目

这应该是一个随心所欲的好地方。

该方法如下所示:

def to_representation(self, data):
    """
    List of object instances -> List of dicts of primitive datatypes.
    """
    # Dealing with nested relationships, data can be a Manager,
    # so, first get a queryset from the Manager if needed
    iterable = data.all() if isinstance(data, models.Manager) else data

    return [
        self.child.to_representation(item) for item in iterable
    ]

但老实说,我看不出你能从中得到什么。您的用例看起来不会带来可衡量的性能提升。