この単純な概念が機能しないように見えることに、私は完全に困惑しています。私はViewModel、Controller、Viewを持っています...
これは私の基本的なViewModelです
public class CreateProfessionalEducationViewModel
{
public Models.ProfessionalEducation ProfessionalEducation;
public int ConsultantId;
public CreateProfessionalEducationViewModel() {} // parameterless constr
}
これらは私の2つのコントローラーメソッドです
public ActionResult Create(int id)
{
var viewModel = new CreateProfessionalEducationViewModel
{
ConsultantId = id
};
return View(viewModel);
}
//
// POST: /ProfessionalEducation/Create
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Create(CreateProfessionalEducationViewModel collection)
{
if (ModelState.IsValid)
{
//db.ProfessionalEducations.Add(professionaleducation);
db.SaveChanges();
return RedirectToAction("Index");
}
return View();
}
そして私の見解…
@model Axxes_Virtual_Resume_MVC.ViewModel.ProfessionalEducation.CreateProfessionalEducationViewModel
@using (Html.BeginForm("Create", "ProfessionalEducation")) {
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<fieldset>
<legend>ProfessionalEducation</legend>
<div class="editor-label">
@Html.LabelFor(model => model.ProfessionalEducation.Year)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.ProfessionalEducation.Year)
@Html.ValidationMessageFor(model => model.ProfessionalEducation.Year)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.ProfessionalEducation.Title)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.ProfessionalEducation.Title)
@Html.ValidationMessageFor(model => model.ProfessionalEducation.Title)
</div>
@Html.HiddenFor(model => model.ConsultantId)
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
何らかの奇妙な理由で、コントローラーの HttpPost Create メソッドにポストバックすると、ViewModel で ConsultantId が 0 になり、ProfessionalEducation が null になります。
これはとても基本的なことですが、何を忘れているのでしょうか?
前もって感謝します!!