使用Automapper映射EditModel

时间:2015-07-31 11:44:15

标签: asp.net-mvc entity-framework automapper viewmodel editmodel

我试图使用Automapper将ViewModel类映射到下面列出的类:

public class Product
{
    [Key]
    public int ProductId { get; set; }
    public string Name { get; set; }
    public ICollection<Color> Color { get; set; }
}

public class Color
{
    [Key]
    public int id { get; set; }
    public string value { get; set; }

    public virtual ICollection<Product> products { get; set; }
}

public class ProductVM
{
    [Key]
    public int ProductId { get; set; }
    public string Name { get; set; }
    public List<int> Color { get; set; }
    public IEnumerable<Color> Colors { get; set; } 
}

使用颜色我将所有可用颜色传递给视图以供用户选择,使用Color属性获取值,在视图中显示以下内容:

@Html.ListBoxFor(model => Model.Color, new MultiSelectList(Model.Colors, "id", "value"));

然后在一个控制器中我有一个Post方法,可以保存它。我尝试使用Automapper来转换类,但它无法映射Color属性,因为它应该通过可用的id获取Color对象。

Mapper.CreateMap<ProductVM, Product>();
Product product = AutoMapper.Mapper.Map<ProductVM, Product>(productVM);
db.Products.Add(product);
db.SaveChanges();

我错过了什么?

2 个答案:

答案 0 :(得分:1)

我在我的解决方案中尝试了一些东西,颜色将为null,因为视图中没有返回选择列表。你的int(颜色)列表不会为null,你可以将它映射到颜色对象。

var productVM = new ProductVM
{
    Name = "Test",
    ProductId = 5,
    Colors = null,
    Color = new List<int> {1, 5, 8}
};

Mapper.CreateMap<int, Color>()
    .ForMember(dest => dest.id, opt => opt.MapFrom(src => src));

Mapper.CreateMap<ProductVM, Product>()
    .ForMember(dest => dest.Color, opt => opt.MapFrom(src => src.Color));

Product product = AutoMapper.Mapper.Map<ProductVM, Product>(productVM);
db.Products.Add(product);
db.SaveChanges();

答案 1 :(得分:0)

这种情况正在发生,因为Automapper并不知道如何从List&lt; int&gt; ICollection的颜色&lt;颜色&gt;颜色。尝试为此创建地图。

Mapper.CreateMap<SourceObject, TargetObject>();
Mapper.CreateMap<SourceOuterObject, TargetOuterObject>()
    .ForMember(dest => dest.TargetList, opt => opt.MapFrom(src => src.SourceSet.SourceList);