我在序列化方面遇到问题。我有一个对象的查询集,例如:
uvs = UserVehicles.objects.all()
这些对象中有些过期了,有些没有过期。我想在序列化程序中有不同的字段,具体取决于到期信息。例如,我想从过期的对象中排除status和distance_travelled字段。最简单的方法是什么?我尝试了下一个代码,但是init方法中的self.object包含一个数组,因此它将删除所有对象的字段,而不仅仅是过期的对象。
serialized_data = UserVehicleSerializer(uvs, many=True).data
class UserVehicleSerializer(serializers.ModelSerializer):
class Meta:
model = UserVehicle
fields = ('type', 'model', 'status', 'distance_travelled',)
def __init__(self, *args, **kwargs):
super(UserVehicleSerializer, self).__init__(*args, **kwargs)
if self.object.is_expired:
restricted = set(('distance_travelled', 'status',))
for field_name in restricted:
self.fields.pop(field_name)
我建议不要将业务逻辑放在序列化程序中。您可以为过期的车辆/对象创建一个单独的序列化器,为活动车辆创建一个单独的序列化器,然后在视图中选择正确的序列化器。这样,如果您的业务逻辑针对每种类型的车辆朝着不同的方向发展,则应该易于管理。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句