我正在尝试映射具有子对象集合的相同类型的对象,并且发现应用于子对象属性的 Ignore() 似乎被嗯...忽略了!
这是一个演示该问题的单元测试。
class A
{
public int Id { get; set; }
public string Name { get; set; }
public ICollection<B> Children { get; set; }
}
class B
{
public int Id { get; set; }
public string Name { get; set; }
}
[TestClass]
public class UnitTest1
{
[TestInitialize()]
public void Initialize()
{
Mapper.CreateMap<A, A>()
.ForMember(dest => dest.Id, opt => opt.Ignore());
Mapper.CreateMap<B, B>()
.ForMember(dest => dest.Id, opt => opt.Ignore());
}
[TestMethod]
public void TestMethod1()
{
A src = new A { Id = 0, Name = "Source", Children = new List<B> { new B { Id = 0, Name = "Child Src" } } };
A dest = new A { Id = 1, Name = "Dest", Children = new List<B> { new B { Id = 11, Name = "Child Dest" } } };
Mapper.Map(src, dest);
}
在 Map 调用之后,A 对象的 Id 属性仍然是 1(如预期),但子 B 对象的 Id 属性从 11 更改为 0。
Why?
AutoMapper 4.1.1 中存在多个错误。
首先是关于UseDestinationValue
: https://github.com/AutoMapper/AutoMapper/issues/568 https://github.com/AutoMapper/AutoMapper/issues/568
其次是关于嵌套集合:https://github.com/AutoMapper/AutoMapper/issues/934 https://github.com/AutoMapper/AutoMapper/issues/934
可怕!解决方法是映射您的B
直接实例:
Mapper.CreateMap<A, A>()
.ForMember(dest => dest.Id, opt => opt.Ignore())
.ForMember(dest => dest.Children, opt => opt.Ignore());
Mapper.CreateMap<B, B>()
.ForMember(dest => dest.Id, opt => opt.Condition((ResolutionContext src) => false));
并添加额外的映射调用:
Mapper.Map(src, dest);
Mapper.Map(src.Children.First(), dest.Children.First()); //example!!!
您可以致电Mapper.Map
循环中:
for (int i = 0; i < src.Children.Count; i++)
{
var srcChild = src.Children[i];
var destChild = dest.Children[i];
Mapper.Map(srcChild, destChild);
}
这将使事情正常进行。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)