0

以下模型允许我处理数据库中的翻译,而无需调整代码以添加语言。

class NameString(models.Model)
    en = models.CharField(max_length=55)
    de = models.CharField(max_length=55)

在名为Item的模型中使用示例:

class Item(models.Model):
    name = models.ForeignKey(NameString)

我使用 ReadOnlyModelViewSet 通过 api 查看。它返回以下 json:

"results": [
    {
        "id": 1,
        "name": 3,
    }
]

我想用给定语言的实际名称替换 json名称字段中的id值。这可以通过注释查询集来实现,例如:

name_field = 'name__{}'.format(self.language())
queryset = Item.objects.annotate(name_value=F(name_field))

如果我使用带有值name_value的序列化程序,我会得到以下 json:

"results": [
    {
        "id": 1,
        "name_value": 'cucumber',
    }
]

我的问题是:我如何编写一个管理器来处理 ItemList 模型中的项目ManyToMany 字段,以便它返回指定语言的查询集?

class ItemList(models.Model):
    items = models.ManyToManyField(Item)

这样我就得到了以下json:

"results": [
    {
        "id": 1,
        "name": "item_list_1",
        "items" [
            {
                "id": 1,
                "name_value": "cucumber"
            },
            {
                "id": 2,
                "name_value": "apple"
            }  
        ],
    }
]
4

2 回答 2

0

我发现了一个不同的功能,可以在不需要经理的情况下解决我的问题。您可以通过以下方式使用序列化器方法字段简单地覆盖类视图序列化器中的 json 字段名称:

class MySerializer(serializers.ModelSerializer):
    name = serializers.SerializerMethodField('get_name_value')

class Meta:
    model = MyModel
    fields = (
        "id",
        "name",
    )

def get_name_value(self, obj):
    return obj.name_value
于 2018-02-28T12:57:44.123 回答
0

更优雅的解决方案!

class MySerializer(serializers.ModelSerializer):
    name = serializers.CharField(source='name_value')

    class Meta:
        model = MyModel
        fields = (
            "id",
            "name",
        )
于 2018-10-01T12:14:12.420 回答