AutoMapper - 使用相同的源和目标对象类型映射

Dea*_*ano 8 c# automapper

我正在使用Automapper来获取两个相同类型的对象,并映射已更改的任何新值.我尝试使用下面的代码,但它不断抛出错误,我甚至不确定这是否可以通过Automapper实现.

例如:

        Mapper.CreateMap<UserDetails, UserDetails>();
        UserDetails userDetails = Mapper.Map<UserDetails, UserDetails>(userDetailsCurrent, userDetailsNew);
Run Code Online (Sandbox Code Playgroud)

基本上,我需要将从新对象"userDetailsNew"进入的任何新值复制到现有对象"userDetailsCurrent" - 即使它们属于同一类型.这样我就可以用新值"更新"现有对象.我这样做的原因是因为我不确定将传递哪些用户详细信息 - 我需要在它们到达时映射它们.

我通常使用Automapper来映射具有相似属性的不同对象 - 但我认为我可以使用Automapper的强大功能以这种方式实现相同的功能.甚至可能有更好的解决方案 - 任何帮助将不胜感激!

Chr*_*mer 8

这似乎对我有用.我的自定义类型:

class MyType
{
    public int MyInt { get; set; }
    public string MyString { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

我的映射代码:

Mapper.CreateMap<MyType, MyType>();
var source = new MyType() {MyInt = 1, MyString = "Hello world"};
var dest = Mapper.Map<MyType, MyType>(source);
Run Code Online (Sandbox Code Playgroud)

除了简单属性之外,您的自定义类型有什么意义?


Cli*_*son 7

这可以使用元组并通过创建派生自 Automapper 的 Abstract TypeConverter 类的自定义类型转换器来完成。

假设您有一个源类和目标类:

public class Person
{
    public string FirstName { get; set; }
    public string LastName { get; set; }

    public override string ToString()
    {
        return string.Format("Firstname: {0}, Lastname: {1}", FirstName, LastName);
    }
}
Run Code Online (Sandbox Code Playgroud)

然后您可以将自定义转换器类型构建为

public class CustomerPersonConverter : TypeConverter<Tuple<Person, Person>, Person>
{
    protected override Person ConvertCore(Tuple<Person, Person> source)
    {
        var orginalValues = source.Item1;
        var updatedValues = source.Item2;

        var result = new Person
            {
                FirstName = string.IsNullOrEmpty(updatedValues.FirstName) ? orginalValues.FirstName : updatedValues.FirstName,
                LastName = string.IsNullOrEmpty(updatedValues.LastName) ? orginalValues.LastName : updatedValues.LastName
            };

        return result;
    }
}
Run Code Online (Sandbox Code Playgroud)

可以像这样使用

var orginal = new Person() {FirstName = "Clifford", LastName = "Mayson"};
        var updated = new Person() {FirstName = "Cliff"};

        Mapper.CreateMap<Tuple<Person, Person>, Person>().ConvertUsing<CustomerPersonConverter>();

        var result = Mapper.Map<Person>(new Tuple<Person, Person>(orginal, updated));

        Console.WriteLine(result);
Run Code Online (Sandbox Code Playgroud)

这将产生保留原始姓氏值的结果,因为它在更新中丢失,但更新名字值,例如。

Firstname: Cliff, Lastname: Mayson
Run Code Online (Sandbox Code Playgroud)


Jar*_*ach 7

这是 Automapper 的已知行为(请参阅问题)。你实际上必须告诉 Automapper:

CreateMap<A,A>();
CreateMap<B,B>();
CreateMap<C,C>();
Run Code Online (Sandbox Code Playgroud)