我应该如何将编辑模型映射到域模型



我正试图了解将编辑模型(从视图表单发布回来)中的字段映射到域模型的最佳方法,以便我可以提交更改()并更新数据库记录(通过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();
}

相关内容

  • 没有找到相关文章

最新更新