我正在浏览ASP.NET MVC上的一些教程(
here和
here),并决定自己尝试一些东西.现在,我有三个表,简历,描述,子描述.这是三个代码:
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条目.但是,我遇到了添加描述的问题.这是我的创建视图:
@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")
}
问题是,由于描述是一个列表,实际上没有任何东西可以添加.我甚至不确定如何解决这个问题.我希望能够添加一个描述,然后可以选择在事后添加一个SubDescription.这甚至是可能的,还是我尝试了一些完全错综复杂的事情?
编辑
添加此编辑以获得更多说明.我正在尝试确定如何让用户在“创建”视图中填充“描述”列表.我正在考虑使用列表框.然后,他们可以选择一个描述,并添加一个SubDescription.但我不是百分之百确定如何做到这一点.我试图将@ Html.EditorFor(model => model.Descriptions)更改为@ Html.ListBoxFor(model => model.Descriptions),但是我得到一个错误,即ListBoxFor没有重载需要1个参数.因为我还是新手并且学习这个,所以我不确定如何完成我想做的事情.
最佳答案 你走在正确的轨道上! ListBoxFor方法有两个参数.第一个是你现在拥有的.第二个参数是IEnumerable< SelectListItem>宾语.
我以前亲自做过这种事情,使用ListBoxFor方法真的很有帮助.您可以创建一个List< SelectListItem>并且每个项目都可以保存存储在Descriptions对象中的信息.
如果您传递List< SelectListItem>从控制器反对View,您可以向用户显示所有Descriptions对象,他们可以选择并添加他们选择的任何对象.
您还可以根据您尝试执行的操作创建单独的视图,并在某些情况下将用户重定向到这些视图.
祝好运! =)