更新時間:2020-08-07 來源:黑馬程序員 瀏覽量:
1. 字段類型和選項參數(shù)
本篇文章我們來繼續(xù)學(xué)習(xí)序列化器類定義中的字段類型和選項參數(shù)。
首先我們來回顧一下序列化器類的基本定義形式:
在定義序列化器類時,我們需要選擇對應(yīng)的字段類型和設(shè)置對應(yī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. 選項參數(shù)
對于序列化器字段的選項參數(shù),分別如下兩類:
·通用選項參數(shù):任意字段類型都擁有的參數(shù)
·常用選項參數(shù):特定字段類型才擁有的參數(shù)
3.1 通用選項參數(shù)
通用選項參數(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ù)校驗時必須傳入 | 
| default | 序列化和反序列化時使用的默認(rèn)值 | 
| label | 用于HTML展示API頁面時,顯示的字段名稱,理解為對字段的注釋說明即可 | 
對于這些通用的選項參數(shù),我們需要重點(diǎn)理解里面紅色部分3個選項參數(shù)的作用,接下來我們來對這些選項參數(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ù)校驗
    serializer = UserSerializer(data=data)
    res = serializer.is_valid()
    if res:
        # 獲取校驗通過之后的數(shù)據(jù)
        print('校驗通過:', serializer.validated_data)
    else:
        # 獲取校驗失敗之后的錯誤提示信息
        print('校驗失?。?#39;, serializer.errors)
示例結(jié)果:

結(jié)果說明:
上面的age字段已經(jīng)設(shè)置的read_only=True,所以在反序列化-數(shù)據(jù)校驗時不必傳入,即使傳了,也會忽略它的存在。
示例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ù)校驗
    serializer = UserSerializer(data=data)
    res = serializer.is_valid()
    if res:
        # 獲取校驗通過之后的數(shù)據(jù)
        print('校驗通過:', serializer.validated_data)
    else:
        # 獲取校驗失敗之后的錯誤提示信息
        print('校驗失?。?#39;, serializer.errors)示例結(jié)果:

結(jié)果說明:
上面的age字段默認(rèn)required=True,表明數(shù)據(jù)校驗時是必傳的,示例中未傳遞age,所以校驗失敗。
將上面示例中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ù)校驗
    serializer = UserSerializer(data=data)
    res = serializer.is_valid()
    if res:
        # 獲取校驗通過之后的數(shù)據(jù)
        print('校驗通過:', serializer.validated_data)
    else:
        # 獲取校驗失敗之后的錯誤提示信息
        print('校驗失?。?#39;, serializer.errors)示例結(jié)果:

結(jié)果說明:
上面的age字段設(shè)置required=Fasle,表明數(shù)據(jù)校驗時可傳可不傳,示例中未傳遞age,校驗也能通過。
示例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對象時,因為user對象中沒有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ù)校驗
    serializer = UserSerializer(data=data)
    res = serializer.is_valid()
    if res:
        # 獲取校驗通過之后的數(shù)據(jù)
        print('校驗通過:', serializer.validated_data)
    else:
        # 獲取校驗失敗之后的錯誤提示信息
        print('校驗失?。?#39;, serializer.errors)示例結(jié)果:

結(jié)果說明:
上面的age字段設(shè)置了一個默認(rèn)值,校驗的data字典中未傳遞age數(shù)據(jù),所以校驗之后的數(shù)據(jù)中age使用了設(shè)置的默認(rèn)值。
小提示:如果反序列化時傳遞的data中包含age,則校驗之后的字典中age的值不再使用default設(shè)置的默認(rèn)值。
3.2 常用選項參數(shù)
常用的選項參數(shù)有如下幾個參數(shù):
小提示:以下4個參數(shù)都是只在數(shù)據(jù)校驗時起作用。
| 參數(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ù)校驗
    serializer = UserSerializer(data=data)
    res = serializer.is_valid()
    if res:
        # 獲取校驗通過之后的數(shù)據(jù)
        print('校驗通過:', serializer.validated_data)
    else:
        # 獲取校驗失敗之后的錯誤提示信息
        print('校驗失敗:', serializer.errors)
結(jié)果說明:

上面的name字段設(shè)置了min_length=6和max_length=20兩個參數(shù),在進(jìn)行數(shù)據(jù)校驗時,會要求name的長度在6-20之間,因為我們傳遞的"smart"長度為5,所以校驗失敗。
4. 內(nèi)容總結(jié)
本次文章我們講解了以下內(nèi)容,大家注意結(jié)合示例代碼來加強(qiáng)對一些常見的選項參數(shù)的理解,下次我們來詳細(xì)講解一下序列化器的序列化功能。
1)常見的字段類型
2)通用選項參數(shù)
3)常用選項參數(shù)
猜你喜歡: