以下模型允许我处理数据库中的翻译,而无需调整代码以添加语言。
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"
}
],
}
]