[非專業翻譯] Mapster - 自定義對映邏輯

玩雙截棍的熊貓發表於2021-07-09

[非專業翻譯] Mapster - 自定義對映邏輯

系列介紹

[非專業翻譯] 是對沒有中文文件進行翻譯的系列部落格,文章由機翻和譯者自己理解構成,和原文相比有所有不同,但意思基本一致。

因個人能力有限,如有謬誤之處還請指正,多多包涵。

正文

本文將說明 Mapster 如何自定義對映邏輯

自定義型別對映

使用 MapWith 方法可以指定特定型別的對映邏輯。

例如將字串對映為 char[]:

TypeAdapterConfig<string, char[]>.NewConfig()
    .MapWith(str => str.ToCharArray());

在某些情況下,應該將對映行為修改為複製例項而不是深度拷貝,出現這種情況時同樣可以使用 MapWith

例如,配置 JObject 對映到 JObject

TypeAdapterConfig<JObject, JObject>.NewConfig()
   .MapWith(json => json);

MapWith 預設不和其它對映配置產生關係,如果想要應用其它對映配置,例如 PreserveReferenceInclude 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));

相關文章