0

EF を使用した ASP.NET MVC 3 プロジェクトでは、複雑なデータ型を処理する方法を理解しようとしています。

私は、プロパティスクールを持つエンティティ学生を持っています。ユーザーがエンティティ Student を作成または編集するときに、ユーザーが DB 内の学校のリストから学校を選択できるようにします。

私は次のモデルを持っています:

public class TesterDB : DbContext
{
    public DbSet<School> Schools { get; set; }

    public DbSet<Student> Students { get; set; }
}    

[DataContract]
public class School
{
    public int ID { get; set; }

    public string Name { get; set; }
}

[DataContract]
public class Student
{
    public int ID { get; set; }

    public string Name { get; set; }

    public School School { get; set; }
}

生徒のコントローラーにメソッドを作成します。

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

    [HttpPost]
    public ActionResult Create(Student student)
    {
        if (ModelState.IsValid)
        {
            db.Students.Add(student);
            db.SaveChanges();
            return RedirectToAction("Index");  
        }

        return View(student);
    }

生徒作成ビュー:

@model Tester.Models.Student
@{
     ViewBag.Title = "Create";
}

<h2>Create</h2>

<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")"   type="text/javascript"></script>

@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
    <legend>Student</legend>

    <div class="editor-label">
        @Html.LabelFor(model => model.Name)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.Name)
        @Html.ValidationMessageFor(model => model.Name)
    </div>

    <p>
        <input type="submit" value="Create" />
    </p>
</fieldset>
}

<div>
     @Html.ActionLink("Back to List", "Index")
</div>

スタッドネット モデルの作成ビューに、DB 内の学校のリストから学校を選択できるコンボ ボックスを追加する方法

ありがとう!

4

1 に答える 1

0

(get) create メソッドで、Schools データを提供するメソッドを追加する必要があります。

public ActionResult Create()
{
    ViewBag.SchoolId = new SelectList(db.Schools, "SchoolId", "Name");
    return View();
}

次に、ビューでこのデータをレンダリングする必要があります。

<fieldset> 
...
    <div class="editor-label">
        @Html.LabelFor(model => model.SchoolId, "School")
    </div>
    <div class="editor-field">
        @Html.DropDownList("SchoolId", String.Empty)
        @Html.ValidationMessageFor(model => model.SchoolId)
    </div>
...
</fieldset>

投稿で学校 ID を取得し、それを学生オブジェクトに適用できるようにします。

[HttpPost]
public ActionResult Create(Student student)
{
    if (ModelState.IsValid)
    {
        db.Students.Add(student);
        db.SaveChanges();
        return RedirectToAction("Index");  
    }
    ViewBag.SchoolId = new SelectList(db.Schools, "SchoolId", "Name", student.SchoolId);
    return View(student);
}
于 2012-07-18T07:59:46.893 に答える