私は、ASP.NET MVCとADO.NET Entity Frameworkを一緒に使用しています。厳密に型付けされたMVCを持つEntity Framework
私のビューとコントローラは厳密にタイプしたいと思っています。
エンティティの関連付けをどのように処理する必要がありますか?
ここに簡単な例を示します。
人には1つの部門があります。部署には0人以上の人がいます。
私のコントローラは、Personオブジェクトとビューへのすべての部門オブジェクトのコレクションのインスタンスを渡します。
public class PersonController : Controller
{
...
//
// GET: /Person/Create
public ActionResult Create()
{
Person Model = new Person();
Model.Id = Guid.NewGuid();
ViewData["Departments"] = db.Department;
return View(Model);
}
...
}
マイビューには、すべての部門をオプションとして含む「部門」ドロップダウンリストがあります。
<% using (Html.BeginForm()) {%>
<fieldset>
<legend>Fields</legend>
<p>
<label for="Id">Id:</label>
<%= Html.TextBox("Id") %>
<%= Html.ValidationMessage("Id", "*") %>
</p>
<p>
<label for="Name">Name:</label>
<%= Html.TextBox("Name") %>
<%= Html.ValidationMessage("Name", "*") %>
</p>
<p>
<label for="Department">Family:</label>
<%= Html.DropDownList("Department", new SelectList((IEnumerable)ViewData["Departments"], "Id", "Name"))%>
<%= Html.ValidationMessage("Department", "*")%>
</p>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
<% } %>
しかし、コントローラに投稿されたPersonオブジェクトは、何の部門を持っていないし、失敗しました!
public class PersonController : Controller
{
...
//
// POST: /Person/Create
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Create(Person Model)
{
try
{
db.AddToPerson(Model);
db.SaveChanges();
return RedirectToAction("Index");
}
catch
{
return View();
}
}
...
}
なぜ「部門」は自動的にモデル人に追加のDropDownListから選択した部門ではないでしょうか?
強く型付けされたビューとコントローラでADO.NETエンティティフレームワークとASP.NET MVCを使用するにはどうすればよいですか?
http://stackoverflow.com/questions/922402/strongly-typed-asp-net-mvc-with -ado-net-entity-framework –