我正在将Django rest框架中的序列化数据提供给我网站上的Javascript数据透视表。如果我有一个名为'created_on'的变量,DRF会将其用作字段名称。我希望在我的数据透视表中显示的标签将转换为'Created On'。
例如,DRF的输出结果如下:
[{"created_on": "2016-04-23"}, {"created_on": "2016-05-23"}]
我想要的是:
[{"Created on": "2016-04-23"}, {"Created on": "2016-05-23"}]
如果没有我重写序列化过程,这可能吗?
答案 0 :(得分:7)
不,在没有覆盖序列化过程的情况下(当前)不可能。
为什么不可能?
这是因为您要用于created_on
的备用名称包含空格,并且无法在序列化程序中定义包含空格的字段。此外,目前没有功能为序列化过程中使用的字段提供备用名称。
可能的解决方案:
您可以覆盖序列化程序的to_representation()
方法,并添加一个Created On
键,其值等于created_on
键的值。然后,所有序列化对象都将包含一个键Created On
。
class MySerializer(serializers.ModelSerializer):
...
def to_representation(self, obj):
primitive_repr = super(MySerializer, self).to_representation(obj)
primitive_repr['Created On'] = primitive_repr['created_on']
return primitive_repr
如果备用名称不包含任何空格怎么办?
如果备用名称之间没有任何空格,则可以使用带有SerializerMethodField()
参数的source
。
你可以做类似的事情:
class MySerializer(serializers.ModelSerializer):
alternate_name = serializers.SerializerMethodField(source='created_on')
class Meta:
model = MyModel
fields = (.., 'alternate_name')