我对 ViewModel 上的编辑视图有一点问题。当我第一次将我的编辑视图发布到服务器时,它需要再次返回编辑视图,并使用已附加数据库 ID 的相同 ViewModel。
这是相应控制器中的 Edit 方法:
[HttpPost]
public ActionResult Edit(InvoiceDetailsViewModel invoice) {
using (var context = new HyperContext(WebSecurity.CurrentUserId)) {
if (ModelState.IsValid) {
if (invoice.ID == 0) {
var dbItem = Mapper.Map<eu.ecmt.RecruitmentDatabase.Models.Invoice>(invoice);
context.Invoices.Add(dbItem);
context.SaveChanges();
var newInvoice = Mapper.Map<InvoiceDetailsViewModel>(dbItem);
FillViewBag(context, newInvoice);
newInvoice.Description = "TEST";
return PartialView(newInvoice);
}
else {
context.Entry(Mapper.Map<eu.ecmt.RecruitmentDatabase.Models.Invoice>(invoice)).State = System.Data.EntityState.Modified;
context.SaveChanges();
return Content(Boolean.TrueString);
}
}
FillViewBag(context, invoice);
return PartialView(invoice);
}
}
这里的相关部分invoice.ID
是 0,发票被保存到 DB 以获取 ID 并返回到 Edit 视图。在那个观点中,我得到了这些线作为初学者:
@model eu.ecmt.RecruitmentDatabase.ViewModels.InvoiceDetailsViewModel
@using (Html.BeginForm("Edit", "Invoice", FormMethod.Post, new { id = "invoices-edit-form" })) {
@Html.ValidationSummary(true)
<script type="text/javascript">
$(document).ready(function () {
//$("#tabs").tabs();
InitProfileUI();
});
</script>
if (Model.ID != 0) {
<script type="text/javascript">
$(document).ready(function () {
LoadList('/InvoiceDetail/List/@Model.ID', '', 'invoice-details');
});
</script>
}
<fieldset>
<legend>Edit contract</legend>
@Html.HiddenFor(m => m.ID)
@Html.HiddenFor(m => m.InvoiceNumber)
@Html.HiddenFor(m => m.Created)
@Html.HiddenFor(m => m.CreatedBy)
@Html.HiddenFor(m => m.Modified)
@Html.HiddenFor(m => m.ModifiedBy)
首次渲染此视图时,包含LoadList
调用的脚本元素不在输出中。当表单发布并使用更新的视图模型呈现视图时,该元素在输出中。但是,包含发票 ID 的隐藏字段仍然显示 0。因此,从本质上讲,这里发生的是 ViewData 字典中的模型对象是正确的版本,表达式中使用的对象似乎成为另一个更旧的版本。
有人愿意解释这一点并指出我正确的方向吗?