在 Mapster 中,默认的配置实例为 TypeAdapterConfig.GlobalSettings
,如果需要在不同场景下有不同的映射配置,Mapster 提供了 TypeAdapterConfig
用于实现此需求:
var config = new TypeAdapterConfig();
config.Default.Ignore("Id");
如何给 配置实例 添加l类型映射配置?
直接使用 NewConfig
和 ForType
方法即可:
config.NewConfig<TSource, TDestination>()
.Map(dest => dest.FullName,
src => string.Format("{0} {1}", src.FirstName, src.LastName));
config.ForType<TSource, TDestination>()
.Map(dest => dest.FullName,
src => string.Format("{0} {1}", src.FirstName, src.LastName));
通过将 配置实例 作为参数传给 Adapt
方法来应用特定的类型映射配置:
注意! 配置实例 在程序中一定要作为单例存在,否则会影响性能!
var result = src.Adapt<TDestination>(config);
也可以创建一个指定 TypeAdapterConfig
的 Mapper
,使用 Mapper
来做映射:
var mapper = new Mapper(config);
var result = mapper.Map<TDestination>(src);
如果想从现有的配置中创建配置实例,可以使用 Clone
方法。
例如 复制全局配置实例 :
var newConfig = TypeAdapterConfig.GlobalSettings.Clone();
或者复制其它配置实例:
var newConfig = oldConfig.Clone();
Fork
方法内部直接调用 Clone
方法,但是使用 Fork
方法的形式与使用 Clone
方法有些许差别。
Fork
方法通过传入委托方法直接增加新的映射配置:
var forked = mainConfig.Fork(config =>
{
config.ForType<Poco, Dto>()
.Map(dest => dest.code, src => src.Id);
});
var dto = poco.Adapt<Dto>(forked);
以上代码等同于使用 Clone
方法实现的以下代码:
var forked = mainConfig.Clone();
forked.ForType<Poco, Dto>()
.Map(dest => dest.code, src => src.Id);
var dto = poco.Adapt<Dto>(forked);