更新時間:2020-08-07 來源:黑馬程序員 瀏覽量:
1. 字段類型和選項(xiàng)參數(shù)
本篇文章我們來繼續(xù)學(xué)習(xí)序列化器類定義中的字段類型和選項(xiàng)參數(shù)。
首先我們來回顧一下序列化器類的基本定義形式:
在定義序列化器類時,我們需要選擇對應(yīng)的字段類型和設(shè)置對應(yīng)的選項(xiàng)參數(shù),接下來我們分別來進(jìn)行講解。
2. 字段類型
下面的表格中我們列出了序列化器中常用的字段類型,對于DRF框架中序列化器所有的字段類型,我們可以到 rest_framework.fields
模塊中進(jìn)行查看。
字段 | 字段構(gòu)造方式 |
---|---|
BooleanField | BooleanField() |
CharField | CharField(max_length=None, min_length=None, allow_blank=False, trim_whitespace=True) |
EmailField | EmailField(max_length=None, min_length=None, allow_blank=False) |
IntegerField | IntegerField(max_value=None, min_value=None) |
FloatField | FloatField(max_value=None, min_value=None) |
DecimalField | DecimalField(max_digits, decimal_places, coerce_to_string=None, max_value=None, min_value=None) max_digits: 最多位數(shù) decimal_palces: 小數(shù)點(diǎn)位置 |
DateTimeField | DateTimeField(format=api_settings.DATETIME_FORMAT, input_formats=None) |
DateField | DateField(format=api_settings.DATE_FORMAT, input_formats=None) |
TimeField | TimeField(format=api_settings.TIME_FORMAT, input_formats=None) |
ChoiceField | ChoiceField(choices) choices與Django的用法相同 |
ImageField | ImageField(max_length=None, allow_empty_file=False, use_url=UPLOADED_FILES_USE_URL) |
我們可以發(fā)現(xiàn),序列化器類定義字段類型和Django框架中的字段類型是一樣,我們只需知道常用的字段類型就可以了,對于其他字段類型,需要的時候再去查看就可以了。
3. 選項(xiàng)參數(shù)
對于序列化器字段的選項(xiàng)參數(shù),分別如下兩類:
·通用選項(xiàng)參數(shù):任意字段類型都擁有的參數(shù)
·常用選項(xiàng)參數(shù):特定字段類型才擁有的參數(shù)
3.1 通用選項(xiàng)參數(shù)
通用選項(xiàng)參數(shù)有如下常見參數(shù):
參數(shù)名稱 | 說明 |
read_only | 默認(rèn)False,若設(shè)置為True,表明對應(yīng)字段只在序列化操作時起作用 |
write_only | 默認(rèn)False,若設(shè)置為True,表明對應(yīng)字段只在反序列化操作時起作用 |
required | 默認(rèn)True,表明對應(yīng)字段在數(shù)據(jù)校驗(yàn)時必須傳入 |
default | 序列化和反序列化時使用的默認(rèn)值 |
label | 用于HTML展示API頁面時,顯示的字段名稱,理解為對字段的注釋說明即可 |
對于這些通用的選項(xiàng)參數(shù),我們需要重點(diǎn)理解里面紅色部分3個選項(xiàng)參數(shù)的作用,接下來我們來對這些選項(xiàng)參數(shù)做一些具體的介紹。
示例1:read_only參數(shù) (注意對比設(shè)置之前和設(shè)置之后的效果)
from rest_framework import serializers class User(object): """用戶類""" def __init__(self, name, age): self.name = name self.age = age class UserSerializer(serializers.Serializer): """序列化器類""" name = serializers.CharField() # 此處將age字段的read_only參數(shù)設(shè)置為True age = serializers.IntegerField(read_only=True) if __name__ == "__main__": # 準(zhǔn)備數(shù)據(jù) data = {'name': 'laowang', 'age': 18} # 數(shù)據(jù)校驗(yàn) serializer = UserSerializer(data=data) res = serializer.is_valid() if res: # 獲取校驗(yàn)通過之后的數(shù)據(jù) print('校驗(yàn)通過:', serializer.validated_data) else: # 獲取校驗(yàn)失敗之后的錯誤提示信息 print('校驗(yàn)失?。?#39;, serializer.errors)
示例結(jié)果:
結(jié)果說明:
上面的age字段已經(jīng)設(shè)置的read_only=True,所以在反序列化-數(shù)據(jù)校驗(yàn)時不必傳入,即使傳了,也會忽略它的存在。
示例2:write_only參數(shù) (注意對比設(shè)置之前和設(shè)置之后的效果)
from rest_framework import serializers class User(object): """用戶類""" def __init__(self, name, age): self.name = name self.age = age class UserSerializer(serializers.Serializer): """序列化器類""" name = serializers.CharField() # 此處將age字段的write_only參數(shù)設(shè)置為True age = serializers.IntegerField(write_only=True) if __name__ == "__main__": # 創(chuàng)建user對象 user = User('smart', 18) # 將user對象序列化為字典{'name': 'smart', 'age': 18} serializer = UserSerializer(user) # serializer.data獲取序列化之后的字典數(shù)據(jù) print(serializer.data)
示例結(jié)果:
結(jié)果說明:
上面的age字段已經(jīng)設(shè)置的write_only=True,所以在進(jìn)行序列化操作時會忽略它的存在,因而上面的序列化之后的數(shù)據(jù)中只會拿user對象name屬性的值,而不會拿user對象的age屬性的值。
示例3:required參數(shù) (注意對比設(shè)置之前和設(shè)置之后的效果)
from rest_framework import serializers class User(object): """用戶類""" def __init__(self, name, age): self.name = name self.age = age class UserSerializer(serializers.Serializer): """序列化器類""" name = serializers.CharField() # 此處age字段的required參數(shù)默認(rèn)為True age = serializers.IntegerField() if __name__ == "__main__": # 準(zhǔn)備數(shù)據(jù) data = {'name': 'laowang'} # 數(shù)據(jù)校驗(yàn) serializer = UserSerializer(data=data) res = serializer.is_valid() if res: # 獲取校驗(yàn)通過之后的數(shù)據(jù) print('校驗(yàn)通過:', serializer.validated_data) else: # 獲取校驗(yàn)失敗之后的錯誤提示信息 print('校驗(yàn)失敗:', serializer.errors)
示例結(jié)果:
結(jié)果說明:
上面的age字段默認(rèn)required=True,表明數(shù)據(jù)校驗(yàn)時是必傳的,示例中未傳遞age,所以校驗(yàn)失敗。
將上面示例中age字段的required設(shè)置為False:
from rest_framework import serializers class User(object): """用戶類""" def __init__(self, name, age): self.name = name self.age = age class UserSerializer(serializers.Serializer): """序列化器類""" name = serializers.CharField() # 此處將age字段的required參數(shù)設(shè)置為False age = serializers.IntegerField(required=False) if __name__ == "__main__": # 準(zhǔn)備數(shù)據(jù) data = {'name': 'laowang'} # 數(shù)據(jù)校驗(yàn) serializer = UserSerializer(data=data) res = serializer.is_valid() if res: # 獲取校驗(yàn)通過之后的數(shù)據(jù) print('校驗(yàn)通過:', serializer.validated_data) else: # 獲取校驗(yàn)失敗之后的錯誤提示信息 print('校驗(yàn)失?。?#39;, serializer.errors)
示例結(jié)果:
結(jié)果說明:
上面的age字段設(shè)置required=Fasle,表明數(shù)據(jù)校驗(yàn)時可傳可不傳,示例中未傳遞age,校驗(yàn)也能通過。
示例4:default參數(shù) (注意對比設(shè)置之前和設(shè)置之后的效果)
1)序列化時所使用的默認(rèn)值
from rest_framework import serializers class User(object): """用戶類""" def __init__(self, name, age): self.name = name self.age = age class UserSerializer(serializers.Serializer): """序列化器類""" name = serializers.CharField() age = serializers.IntegerField() addr = serializers.CharField(default='默認(rèn)地址') if __name__ == "__main__": # 創(chuàng)建user對象 user = User('smart', 18) # 將user對象序列化為字典{'name': 'smart', 'age': 18} serializer = UserSerializer(user) # serializer.data獲取序列化之后的字典數(shù)據(jù) print(serializer.data)
示例結(jié)果:
結(jié)果說明:
上面的addr字段設(shè)置了一個default默認(rèn)值,在序列化user對象時,因?yàn)閡ser對象中沒有addr屬性,所以序列化之后的數(shù)據(jù)中addr使用了默認(rèn)值。
小提示:如果user對象有addr屬性,則序列化之后的字典中addr的值不再使用default設(shè)置的默認(rèn)值。
2)反序列化時所使用的默認(rèn)值
from rest_framework import serializers class User(object): """用戶類""" def __init__(self, name, age): self.name = name self.age = age class UserSerializer(serializers.Serializer): """序列化器類""" name = serializers.CharField() # 注:一旦一個字段設(shè)置了default,則這個字段的required默認(rèn)為False age = serializers.IntegerField(default=20) if __name__ == "__main__": # 準(zhǔn)備數(shù)據(jù) data = {'name': 'laowang'} # 數(shù)據(jù)校驗(yàn) serializer = UserSerializer(data=data) res = serializer.is_valid() if res: # 獲取校驗(yàn)通過之后的數(shù)據(jù) print('校驗(yàn)通過:', serializer.validated_data) else: # 獲取校驗(yàn)失敗之后的錯誤提示信息 print('校驗(yàn)失敗:', serializer.errors)
示例結(jié)果:
結(jié)果說明:
上面的age字段設(shè)置了一個默認(rèn)值,校驗(yàn)的data字典中未傳遞age數(shù)據(jù),所以校驗(yàn)之后的數(shù)據(jù)中age使用了設(shè)置的默認(rèn)值。
小提示:如果反序列化時傳遞的data中包含age,則校驗(yàn)之后的字典中age的值不再使用default設(shè)置的默認(rèn)值。
3.2 常用選項(xiàng)參數(shù)
常用的選項(xiàng)參數(shù)有如下幾個參數(shù):
小提示:以下4個參數(shù)都是只在數(shù)據(jù)校驗(yàn)時起作用。
參數(shù)名稱 | 作用 |
max_length | 字符串最大長度 |
min_length | 字符串最小長度 |
max_value | 數(shù)字最大值 |
min_value | 數(shù)字最小值 |
參數(shù)說明:
·max_length和min_length是針對字符串類型的參數(shù);
·max_value和min_value是針對數(shù)字類型的參數(shù)。
示例1:max_length和min_length
示例結(jié)果:
from rest_framework import serializers class User(object): """用戶類""" def __init__(self, name, age): self.name = name self.age = age class UserSerializer(serializers.Serializer): """序列化器類""" name = serializers.CharField(min_length=6, max_length=20) # 此處age字段的required參數(shù)默認(rèn)為True age = serializers.IntegerField() if __name__ == "__main__": # 準(zhǔn)備數(shù)據(jù) data = {'name': 'smart'} # 數(shù)據(jù)校驗(yàn) serializer = UserSerializer(data=data) res = serializer.is_valid() if res: # 獲取校驗(yàn)通過之后的數(shù)據(jù) print('校驗(yàn)通過:', serializer.validated_data) else: # 獲取校驗(yàn)失敗之后的錯誤提示信息 print('校驗(yàn)失敗:', serializer.errors)
結(jié)果說明:
上面的name字段設(shè)置了min_length=6和max_length=20兩個參數(shù),在進(jìn)行數(shù)據(jù)校驗(yàn)時,會要求name的長度在6-20之間,因?yàn)槲覀儌鬟f的"smart"長度為5,所以校驗(yàn)失敗。
4. 內(nèi)容總結(jié)
本次文章我們講解了以下內(nèi)容,大家注意結(jié)合示例代碼來加強(qiáng)對一些常見的選項(xiàng)參數(shù)的理解,下次我們來詳細(xì)講解一下序列化器的序列化功能。
1)常見的字段類型
2)通用選項(xiàng)參數(shù)
3)常用選項(xiàng)參數(shù)
猜你喜歡: