我正试图了解将编辑模型(从视图表单发布回来)中的字段映射到域模型的最佳方法,以便我可以提交更改()并更新数据库记录(通过Linq to SQL)。我的例子将是简单的,它的答案可能只是手动执行。我要问的问题是,对于具有更多字段的模型,它仍然可以手动完成,也许这就是答案-但是是否有更简单的方法(使用AutoMapper也许)?
My Domain Model:
public class Product
{
public int ProductId { get; set; }
public string Name { get; set; }
public int Color { get; set; }
public string SerialNumber { get; set; }
}
My View/Edit Model:
public class ProductVM
{
public int ProductId { get; set; }
public string Name { get; set; }
public IEnumberable<Color> Colors { get; set; } // To populate a dropdown in the view with color key/values
}
My Controller Action:
[HttpPost]
public ActionResult UpdateProduct(ProductVM product)
{
var productService = new ProductService();
productService.Update(product);
}
服务层中的Update方法:
public void Update(ProductVM productVM)
{
Product product = dataContext.Products.Single(p=>p.ProductId == productVM.ProductId);
// What's the best way to map the fields of productVM into product so I can submit the changes?
dataContext.SubmitChanges();
}
我只想映射productVM中与product中字段匹配的字段。编辑模型具有域模型中不存在的字段,而域模型具有编辑模型中不存在的字段。我的最终目标是从Edit Model中的字段更新数据库中的字段。
谢谢
使用 Automapper
public void Update(ProductVM productVM)
{
Product product = dataContext.Products.Single(p=>p.ProductId == productVM.ProductId);
AutoMapper.Mapper.DynamicMap<ProductVM, Product >(productVM, product );
dataContext.SubmitChanges();
}