3

鉴于以下情况:

var object1 = new A() { Equipment = new List<FooEquipment>() { new FooEquipment() } };
var object2 = new B() { Equipment = new List<FooEquipment>() { new FooEquipment() } );

var list = new List<Foo>() { object1, object2 };

(我继承了一些遗留代码,列表应该在 A 和 B 的基类中)。

随着一些新的课程,

public class AFooEquipment : FooEquipment
{
}

public class BFooEquipment : FooEquipment
{
}

我可以使用 AutoMapper 将它们转换FooEquipmentsAFooEquipmentBFooEquipment以某种方式检查它们的父项吗?即在映射器中,我会看到 object1 在 typeof(A) 类中,因此我将其设备转换为 -> List<AFooEquipment>。它会看到 object2 在 typeof(B) 类中,所以我转换它的设备 -> List<BFooEquipment>

那可能吗?

4

1 回答 1

1

我正在使用 AutoMapper 3,因此这可能对您不起作用,但一种选择是使用ResolutionContextandConstructUsing方法,如下所示:

CreateMap<Foo, Foo>()
  .Include<A, Foo>()
  .Include<B, Foo>();
CreateMap<A, A>();
CreateMap<B, B>();
CreateMap<FooEquipment, FooEquipment>()
  .ConstructUsing((ResolutionContext ctx) =>
  {
    if (ctx.Parent != null) // Parent will point to the Equipment property
    {
      var fooParent = ctx.Parent.Parent; // Will point to Foo, either A or B.
      if (fooParent != null)
      {
        if (fooParent.SourceType == typeof(A)) return new AFooEquipment();
        if (fooParent.SourceType == typeof(B)) return new BFooEquipment();
      }
    }
    return new FooEquipment();
  });

如果你然后打电话给Mapper.Map<IEnumerable<Foo>>(list)它应该给你你想要的。或者我怀疑你想要什么:)

于 2014-10-21T22:01:04.600 回答