c# – 通过用户输入将项目添加到列表中

我正在浏览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对象,他们可以选择并添加他们选择的任何对象.

您还可以根据您尝试执行的操作创建单独的视图,并在某些情况下将用户重定向到这些视图.

祝好运! =)

点赞