dar*_*tar 2 python django django-models django-rest-framework
所以基本上我有一个 django 模型,它有一个 ManyToManyField 的朋友和两个在其上运行的方法。这是我的文件:
模型.py:
from django.db import models
from django.contrib.auth.models import User
class Profile(models.Model):
first_name = models.CharField(max_length=50, blank=True)
last_name = models.CharField(max_length=50, blank=True)
user = models.OneToOneField(User, on_delete=models.CASCADE)
friends = models.ManyToManyField(User, blank=True, related_name='friends')
def friends_list(self):
return self.friends.all()
def number_of_friends(self):
return self.friends.all().count()
Run Code Online (Sandbox Code Playgroud)
序列化器.py:
from rest_framework import serializers
from .models import Profile
class ProfileSerializer(serializers.ModelSerializer):
class Meta:
model = Profile
fields = '__all__'
Run Code Online (Sandbox Code Playgroud)
视图.py:
from rest_framework import viewsets, permissions
from .models import Profile
from .serializers import ProfileSerializer
class ProfileViewSet(viewsets.ModelViewSet):
queryset = Profile.objects.all()
permission_classes = [
permissions.AllowAny
]
serializer_class = ProfileSerializer
Run Code Online (Sandbox Code Playgroud)
问题是在 Api 中,方法的返回值不存在。例如,friends_list 方法应该返回您拥有的朋友列表,尽管这在传统的 django 项目中确实有效,但 Django Rest Framework 并未显示此方法的任何值。我该如何解决这个问题并让这两种方法的返回值显示在 api 中?
由于模型序列化器仅选取序列化器字段的模型字段,因此您不会自动复制任何方法。
您仍然可以通过引用模型方法显式添加两个字段来通过 API发送此只读数据
class ProfileSerializer(serializers.ModelSerializer):
class Meta:
model = Profile
fields = [
# need to explicitly define all fields I believe
'friends_list',
'number_of_friends',
]
Run Code Online (Sandbox Code Playgroud)
现在已经声明了两个字段(与方法名称匹配),DRF 应该为每个字段创建SerializerMethodField
orReadOnly
字段(不确定是哪一个,但它们是相似的)。它可以工作,因为它将这些字段的源设置为相同的名称,如果在模型上找到某些属性(在本例中为方法)。
如果这不起作用,您可以
class ProfileSerializer(serializers.ModelSerializer):
friends_list = serializers.SerializerMethodField()
number_of_friends = serializers.SerializerMethodField()
class Meta:
model = Profile
fields = [
# need to explicitly define all fields I believe
'friends_list',
'number_of_friends',
]
def get_friends_list(self, instance):
return instance.friends_list()
def get_number_of_friends(self, instance):
return instance.number_of_friends()
Run Code Online (Sandbox Code Playgroud)