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

时间:2010-01-18 19:53:43

标签: asp.net-mvc linq-to-sql multi-select selectlistitem

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

public MultiSelectList Companies { get; private set; }

Companies = MulitSelectList(subcontractRepository.SubcontractCompanies(Subcontract.subcontract_id), "Value", "Text");
在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
     }
}

在视图中:

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

2 个答案:

答案 0 :(得分:8)

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

答案 1 :(得分:2)

MultiSelectList构造函数有第四个参数 - 选定的项目。使用它:

http://msdn.microsoft.com/en-us/library/system.web.mvc.multiselectlist.multiselectlist.aspx

使用此代码:

public class SelectCompanyItem
{
    public string Name { get; set; }
    public Guid Id { get; set; }
}

public IEnumerable<SelectCompanyItem> SubcontractCompanies(Guid id)
{
     return c in db.companies
     select new SelectCompanyItem
     {
          Name = c.company_name,
          Id = c.company_id
     }
}

var companiesList = subcontractRepository.SubcontractCompanies(Subcontract.subcontract_id);
Companies = new MultiSelectList(companiesList , "Id", "Name", companiesList.Select(a => a.Id));

有效吗?