[非專業翻譯] Mapster – 自定義映射邏輯
[非專業翻譯] Mapster – 自定義映射邏輯
系列介紹
[非專業翻譯] 是對沒有中文文檔進行翻譯的系列博客,文章由機翻和譯者自己理解構成,和原文相比有所有不同,但意思基本一致。
因個人能力有限,如有謬誤之處還請指正,多多包涵。
正文
本文將說明 Mapster 如何自定義映射邏輯
自定義類型映射
使用 MapWith 方法可以指定特定類型的映射邏輯。
例如將字符串映射為 char[]:
TypeAdapterConfig<string, char[]>.NewConfig()
.MapWith(str => str.ToCharArray());
在某些情況下,應該將映射行為修改為複製實例而不是深度拷貝,出現這種情況時同樣可以使用 MapWith。
例如,配置 JObject 映射到 JObject :
TypeAdapterConfig<JObject, JObject>.NewConfig()
.MapWith(json => json);
MapWith 默認不和其它映射配置產生關係,如果想要應用其它映射配置,例如 PreserveReference 、 Include AfterMapping 等方法,只需在調用 MapWith 方法的時候將 applySettings 參數設置為 true 即可:
TypeAdapterConfig<ComplexPoco, ComplexDto>.NewConfig()
.PreserveReference(true)
.MapWith(poco => poco.ToDto(), applySettings: true);
自定義到現有對象的映射數據
通過 MapToTargetWith 方法可以控制到現有對象邏輯的映射。
例如,可以將數據複製到現有數組中:
TypeAdapterConfig<string[], string[]>.NewConfig()
.MapToTargetWith((src, dest) => Array.Copy(src, dest, src.Length));
注意!如果配置了
MapWith,但沒有配置MapToTargetWith,Mapster 將使用MapWith的映射配置。
自定義映射完成後的操作
有些情況下,不需要完全自定義映射邏輯;可以讓 Mapster 自動處理映射,然後通過 AfterMapping 方法在映射完成後對映射結果進行處理:
TypeAdapterConfig<Poco, Dto>.NewConfig()
.AfterMapping((src, dest) => SpecialSetFn(src, dest));


