多选列表未使用linq2sql显示c#mvc中的选定项目

Rem*_*rME 8 asp.net-mvc multi-select selectlistitem linq-to-sql

我已经尝试了许多不同的方法将所选项目传递到多选列表而没有运气.最后,我尝试了这个,我认为应该显示所有选中的项目,但仍然没有选择列表中的任何内容.

public MultiSelectList Companies { get; private set; }

Companies = MulitSelectList(subcontractRepository.SubcontractCompanies(Subcontract.subcontract_id), "Value", "Text");
Run Code Online (Sandbox Code Playgroud)

在SubcontractRepository.cs中:

public IEnumerable<SelectListItem> SubcontractCompanies(Guid id)
{
     return c in db.companies
     select new SelectListItem
     {
          Text = c.company_name,
          Value = c.company_id.ToString(),
          Selected = true
     }
}
Run Code Online (Sandbox Code Playgroud)

在视图中:

<p>
    <label for="Companies">Company:</label>
    <%= Html.ListBox("Companies", Model.Companies) %>
    <%= Html.ValidationMessage("Companies", "*") %>
</p>
Run Code Online (Sandbox Code Playgroud)

Rem*_*rME 8

在这里发现了这个问题.MultiSelectList必须与ListBox具有不同的名称.做了这个改变,现在两个版本的代码都有效.