我试图使用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();
我错过了什么?
答案 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);