이전 질문의 연속입니다. 스티븐의 도움으로 MVC 드롭 다운 포스트 백 문제
MVC Dropdown using ViewModels without Magic String
, 나는 지금은 편집 방법과 도움이 필요, 작성 방법이 작동하게 관리 할 수 있습니다.나는 Get Edit() 메소드를 가져올 수 있지만 다시 게시하면 드롭 다운의 새 값을 저장하지 않습니다. 디버거를 사용하고 이유를 볼 수 없습니다. 그것은 그것이 가정하고 있었던 것처럼하고있는 것처럼 보였다.
// GET: Parents/Edit/5
public ActionResult Edit(int? id)
{
if (id == null)
{
return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
}
Parent parent = db.Parents.Find(id);
if (parent == null)
{
return HttpNotFound();
}
ParentVM viewModel = new ParentVM()
{
CourtList = new SelectList(db.Courts, "CourtId", "CourtName"),
SelectedCourt = parent.Court.CourtId,
ParentID = parent.ParentID,
FirstName = parent.FirstName,
LastName = parent.LastName,
Children = parent.Childs.Select(c => new ChildVM()
{
ChildID = c.ChildID,
ParentID = c.ParentID,
Name = c.Name,
DOB = c.DOB,
Address = c.Address
}).ToList(),
};
return View(viewModel);
}
// POST: Parents/Edit/5
// To protect from overposting attacks, please enable the specific properties you want to bind to, for
// more details see http://go.microsoft.com/fwlink/?LinkId=317598.
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Edit(ParentVM viewModel)
{
if (ModelState.IsValid)
{
Court court = db.Courts.Find(viewModel.SelectedCourt);
var parent = new Parent()
{
FirstName = viewModel.FirstName,
LastName = viewModel.LastName,
ParentID = viewModel.ParentID,
Court = court
};
db.Entry(parent).State = EntityState.Modified;
foreach (ChildVM item in viewModel.Children)
{
var child = new Child()
{
Name = item.Name,
DOB = item.DOB,
Address = item.Address,
ParentID = viewModel.ParentID,
ChildID = item.ChildID
};
db.Entry(child).State = child.ChildID == 0 ?
EntityState.Added :
EntityState.Modified;
}
var findChild = db.Childs.Where(x => x.ParentID == viewModel.ParentID).ToList();
foreach (var item in findChild)
{
var deleteChild = viewModel.Children.Where(x => x.ChildID == item.ChildID).SingleOrDefault();
if (deleteChild == null)
{
db.Childs.Remove(item);
}
}
db.SaveChanges();
return RedirectToAction("Index");
}
viewModel.CourtList = new SelectList(db.Courts, "CourtId", "CourtName");
return View(viewModel);
}
게시물을 처리하려면 다른 방법이 필요합니다. 그 하나는 얻는 것입니다. –
둘 다 거기에 있습니다. 아래로 스크롤해야합니다. –
db.SaveChanges()에 중단 점 넣기; 그것이 맞았는지 확인하십시오. 그렇다면이 시점에서 db.Courts를보고 업데이트 된 값을 보유하고 있는지 확인하십시오. – Gouda