ASP.NET MVC に関するいくつかのチュートリアル (こことここ) を試してみて、自分でいくつかのことを試すことにしました。Resume
これで、 、Descriptions
、 の3 つのテーブルができましたSubDescriptions
。3つのコードは次のとおりです。
public class Resume
{
public Resume()
{
Descriptions = new List<Description>();
}
[Key]
public int ResumeId { get; set; }
[Required]
public string Employer { get; set; }
[DataType(DataType.Date)]
public DateTime StartDate { get; set; }
[DataType(DataType.Date)]
public DateTime EndDate { get; set; }
[Required]
public string Location { get; set; }
[Required]
public virtual ICollection<Description> Descriptions { get; set; }
}
public class Description
{
public Description()
{
SubDescriptions = new List<SubDescription>();
}
[Key]
public int DescriptionId { get; set; }
[ForeignKey("Resume")]
public int ResumeId { get; set; }
[Required]
public string Desc { get; set; }
public virtual Resume Resume { get; set; }
public virtual ICollection<SubDescription> SubDescriptions { get; set; }
}
public class SubDescription
{
[Key]
public int SubDescriptionId { get; set; }
[ForeignKey("Description")]
public int DescriptionId { get; set; }
[Required]
public string Sub { get; set; }
public virtual Description Description { get; set; }
}
今、私が抱えている問題はCreate
ビューにあります。Resume
新しいエントリを作成したいと思います。ただし、追加で問題が発生していDescriptions
ます。これが私のCreate
見解です:
@model Portfolio.Models.Resume
@{
ViewBag.Title = "Create";
}
<h2>Create</h2>
@using (Html.BeginForm())
{
@Html.ValidationSummary(true)
<fieldset>
<legend>Resume</legend>
<div class="editor-label">
@Html.LabelFor(model => model.Employer)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Employer)
@Html.ValidationMessageFor(model => model.Employer)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Title)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Title)
@Html.ValidationMessageFor(model => model.Title)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.StartDate)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.StartDate)
@Html.ValidationMessageFor(model => model.StartDate)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.EndDate)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.EndDate)
@Html.ValidationMessageFor(model => model.EndDate)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Location)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Location)
@Html.ValidationMessageFor(model => model.Location)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Descriptions)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Descriptions)
@Html.ValidationMessageFor(model => model.Descriptions)
</div>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
問題は、Descriptions
はリストであるため、実際に追加するものは何も表示されないことです。私はこれについて行く方法についてさえ確信が持てません。を追加できるようにしたいのですが、事後Description
に追加することを選択できSubDescription
ます。これは可能ですか、それとも完全に複雑なことを試みていますか?
編集
もう少し明確にするために、この編集を追加します。Descriptions
ユーザーがビューのリストにデータを入力する方法を決定しようとしていCreate
ます。私はこれに alistbox
を使用することを考えていました。次に、 を選択してDescription
を追加できますSubDescription
。しかし、私はそれを行う方法について100%確信が持てません。を に変更しようとしました@Html.EditorFor(model => model.Descriptions)
が@Html.ListBoxFor(model => model.Descriptions)
、エラーが発生しましたno overload for ListBoxFor takes 1 argument.
。私はまだ新しく、これを学んでいるので、やりたいことを達成する方法がわかりません。