在序列多個數(shù)據(jù)時,我們需要指定一個關鍵字many=True
創(chuàng)新互聯(lián)服務項目包括港南網站建設、港南網站制作、港南網頁制作以及港南網絡營銷策劃等。多年來,我們專注于互聯(lián)網行業(yè),利用自身積累的技術優(yōu)勢、行業(yè)經驗、深度合作伙伴關系等,向廣大中小型企業(yè)、政府機構等提供互聯(lián)網行業(yè)的解決方案,港南網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到港南省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!
這是為什么呢?
其實是,當序列化器產生對象時,傳入參數(shù)many和不傳入會生成兩個不同的對象??!
這是怎么實現(xiàn)的呢??
1.類的對象生成--先調用類的__new__方法生成一個空對象
2.對象 = 類名(name=‘lz’)--會觸發(fā)類的__init__方法,產生一個有屬性的對象
3.類的__new__方法是控制對象生成
所以,找BookSerializer類的__new__方法,該類沒有就往它的父類找,最后在BaseSerializer這個類中找到了__new__方法??!
def __new__(cls, *args, **kwargs):
if kwargs.pop('many', False):
# 當 傳入many=True 執(zhí)行類的many_init方法
return cls.many_init(*args, **kwargs)
# 當未傳入時,正常生成我們定義的序列化器類
return super().__new__(cls, *args, **kwargs)
many_init該方法意思是單次生成多個我們自己定義的BookSerializer對象,然后添加到列表中??!
@classmethod
def many_init(cls, *args, **kwargs):
allow_empty = kwargs.pop('allow_empty', None)
max_length = kwargs.pop('max_length', None)
min_length = kwargs.pop('min_length', None)
child_serializer = cls(*args, **kwargs)
list_kwargs = {
'child': child_serializer,
}
if allow_empty is not None:
list_kwargs['allow_empty'] = allow_empty
if max_length is not None:
list_kwargs['max_length'] = max_length
if min_length is not None:
list_kwargs['min_length'] = min_length
list_kwargs.update({
key: value for key, value in kwargs.items()
if key in LIST_SERIALIZER_KWARGS
})
meta = getattr(cls, 'Meta', None)
list_serializer_class = getattr(meta, 'list_serializer_class', ListSerializer)
return list_serializer_class(*args, **list_kwargs)