1

我有一个包含文本框和下拉框的 ViewModel,我想将数据保存到 MVC3 中的数据库中。

我通常会这样做:

if (ModelState.IsValid)
{
    db.Orders.Add(orders);
    db.SaveChanges();
    return RedirectToAction("Index");  
}

我将如何保存 ViewModel?

提前致谢

编辑好的,所以我得到了这个 ViewModel:

namespace DropDownList.Models
{
public class CreditCardModel
{
public List<SelectListItem> CardTypeOptions { get; set; }

[Display(Name = "Card Type")]
public string CardTypeID { get; set; }

[Display(Name = "Card Number")]
[Required(ErrorMessage = "Please provide your card number")]
public string CardNumber { get; set; }
}
}

and this controller:
namespace DropDownList.Controllers
{
public class CreditCardModelController : Controller
{
//
// GET: /CreditCardModel/
public ActionResult Index()
{
var model = new CreditCardModel();
// Populate the dropdown options
model.CardTypeOptions = GetCardTypes("MS"); // Set the default to American Express

return View(model);
}

[HttpPost]
public ActionResult Index(CreditCardModel model)
{
if (ModelState.IsValid)

{
return RedirectToAction("addcardcomplete");
}
// TODO - Handle the form submit
// Populate the dropdown options
model.CardTypeOptions = GetCardTypes("MS"); // Set the default to American Express

return View(model);
}
// TODO - AddCardComplete goes here



// TODO - GetCardTypes goes here

private List<SelectListItem> GetCardTypes(string defaultValue)
{
List<SelectListItem> items = new List<SelectListItem>();
items.Add(new SelectListItem { Text = "American Express", Value = "AE", Selected = (defaultValue == "AE") });
items.Add(new SelectListItem { Text = "Mastercard", Value = "MS", Selected = (defaultValue     == "MS") });
items.Add(new SelectListItem { Text = "Visa", Value = "VS", Selected = (defaultValue == "VS") });
return items;
}

public ActionResult AddCardComplete()
{
return View();
}
}
}

我将如何保存这些数据?一旦iv学会了这一点,我就可以将其应用于实际场景

谢谢

4

2 回答 2

2

创建实体模型的实例并设置您从 ViewModel 中读取的值,该值已发布到操作方法,并将其用于保存到数据库。像这样的东西。

[HttpPost]
public ActionResult SaveOrder(OrderViewModel orderVM)
{
  if(ModelState.IsValid)
  {
    YourDomainEntity objDomainModel=new YourDomainEntity();
    objDomainModel.ItemId=orderVm.ItemId;
    objDomainModel.Quantity=orderVM.Quantity;
    //Set Other relevant properties also

    db.Orders.Add(orders);
    db.SaveChanges();
    return RedirectToAction("Index"); 

  } 
}

您可以考虑使用AutoMapper 之类的库来将您的域对象映射到您的 ViewModel。

于 2012-04-23T00:35:37.443 回答
0

我猜你的意思是编辑?您可以将其重新附加为已修改并重新保存..

db.Orders.Attach(orders, true);
db.ObjectStateManager.ChangeObjectState(orders, EntityState.Modified);
db.SaveChanges();

尽管我强烈建议您拆分数据库对象和视图模型。您还可以使用AutoMapper来简化来回操作,但保持数据库和前端分离。

于 2012-04-23T00:34:54.463 回答