Znalezienie dokumentacji ramowej Django-REST, mimo długiego czasu, wciąż jest dla mnie zbyt lekkie.Django-REST framework restore_object Parametry attrs
Co robi funkcja attrs metody restore_object?
instance.title = attrs.get('title', instance.title)
Co kryje się za drugim argumentem i jak powinienem szukać tego, co oznaczałoby to w przyszłości w dokumentach?
Także nie wiesz, co oznacza podwójna gwiazdka w kodzie return Snippet(**attrs)
. To różni się od ** keywArgs? Jakie argumenty są przekazywane z powrotem do obiektu Snippet zserializowanego?
W innej sekcji dokumentów widzę w restore_object() instance.title = attrs['title']
, które mam nadzieję, że ktoś może zobaczyć moje zamieszanie.
dziękuję
class SnippetSerializer(serializers.Serializer):
pk = serializers.Field() # Note: `Field` is an untyped read-only field.
title = serializers.CharField(required=False,
max_length=100)
code = serializers.CharField(widget=widgets.Textarea,
max_length=100000)
linenos = serializers.BooleanField(required=False)
language = serializers.ChoiceField(choices=LANGUAGE_CHOICES,
default='python')
style = serializers.ChoiceField(choices=STYLE_CHOICES,
default='friendly')
def restore_object(self, attrs, instance=None):
"""
Create or update a new snippet instance.
"""
if instance:
# Update existing instance
instance.title = attrs.get('title', instance.title)
instance.code = attrs.get('code', instance.code)
instance.linenos = attrs.get('linenos', instance.linenos)
instance.language = attrs.get('language', instance.language)
instance.style = attrs.get('style', instance.style)
return instance
# Create new instance
return Snippet(**attrs)
zastanawiałem się dokładnie to samo. – alejoss