我已阅读此问题ASP.NET MVC DropDownListFor not selecting value from model并回答,但我不知道解决问题的方法。
这是我的观点:
@foreach (var adjusterLanguages in Model.adjusterLanguages)
{
<div class="editor-field row">
@Html.DropDownListFor(model => Model.adjusterLanguages[i].languageID,
(SelectList)ViewBag.ForeignLanguages)
@Html.ValidationMessageFor(model =>Model.adjusterLanguages[i].languageID)
</div>
<div style="clear: left;"></div>
i++;
}
我可以确认正在填充模型数据(来自我的控制器):
model.adjusterLanguages = adjLangs;
那么,如何在模型发送到视图时选择项目?
生成的html如下:
<div class="editor-field row">
<select id="adjusterLanguages_0__languageID" name="adjusterLanguages[0].languageID"><option value="">--Select--
</option>
<option value="94c5be88-814e-4719-9784-587eb88aa975">Afrikanns</option>
<option value="37b7bf71-7f4e-47c2-8b81-652b0d63dbcb">Albanian</option>
<option value="c94d6d85-0ba2-47d7-932e-2a61feba37b3">Arabic</option>
<!-- ... truncated for brevity ... -->
</select>
<span class="field-validation-valid" data-valmsg-for="adjusterLanguages[0].languageID" data-valmsg-replace="true"></span>
</div>
<div style="clear: left;"></div>
<div class="editor-field row">
<select id="adjusterLanguages_1__languageID" name="adjusterLanguages[1].languageID">
<option value="">--Select--</option>
<option value="94c5be88-814e-4719-9784-587eb88aa975">Afrikanns</option>
<option value="37b7bf71-7f4e-47c2-8b81-652b0d63dbcb">Albanian</option>
<option value="c94d6d85-0ba2-47d7-932e-2a61feba37b3">Arabic</option>
<!-- ... truncated for brevity ... -->
</select>
<span class="field-validation-valid" data-valmsg-for="adjusterLanguages[1].languageID" data-valmsg-replace="true"></span>
</div>
答案 0 :(得分:30)
我找到了答案!感谢大家的帮助。当我将代码更改为以下代码时,它可以正常工作。代码只是指定选定的值:
@Html.DropDownListFor(
model => Model.adjusterLanguages[i].languageID,
new SelectList(
ViewBag.ForeignLanguages, "Value", "Text",
@Model.adjusterLanguages[i].languageID))
答案 1 :(得分:4)
当你在控制器中填充ViewBag.ForeignLanguages
时,在应该选择的项目上,将.Selected
属性设置为true。
但是,您会遇到此问题,因为您有许多项目使用相同的ForeignLangauges
项目列表。
您需要为列表中的每个adjusterLanguages
创建一个列表。他们无法共享相同的列表,因为adjusterLanguages[0]
需要选择的项目不同于adjusterLanaguages[1]
修改强>
我喜欢这个模型:
public class AdjusterLanguageModel
{
public Guid LanguageId { get; set; }
List<SelectListItem> ForeignLanguages{ get; set; }
}
public class AdjusterListModel
{
public List<AdjusterLanguageModel> AdjusterLanguages { get; set }
}
在控制器中,您使用ID和它自己的可用语言列表填充列表。
在您看来:
@foreach (var adjusterLanguages in Model.AdjusterLanguages)
{
<div class="editor-field row">
@Html.DropDownListFor(model => adjusterLanguages[i].LanguageID,
adjusterLanguages[i].ForeignLanguages)
@Html.ValidationMessageFor(model => adjusterLanguages[i].LanguageID)
</div>
<div style="clear: left;"></div>
i++;
}
所以每个DropDownListFor
都得到它自己的语言列表。
答案 2 :(得分:1)
在我看来,ViewBag.ForeignLanguages
中的一项应将Selected
属性设置为true
。 DropDownListFor方法根据ModelState选择项目。 Here 你有DropDownListFor方法的源代码,有类似的东西:
object defaultValue = (allowMultiple) ? htmlHelper.GetModelStateValue(fullName, typeof(string[])) : htmlHelper.GetModelStateValue(fullName, typeof(string));
如果该值为null,则从Selected
属性
答案 3 :(得分:1)
我知道这是一个老问题,但万一有人面临与我相同的问题。在我的情况下,我不小心使用了普通变量而不是模型中的属性,只要我将其设置为属性而不是它开始工作。
答案 4 :(得分:0)
我添加了一个扩展方法来强制执行值选择。它还会在页面重新加载时保留视图状态数据。
public static class SelectListExtensions
{
public static SelectList SelectValue(this SelectList selectList, object value)
{
return new SelectList(selectList, "Value", "Text", value);
}
}
用法是:
selectList = selectList.SelectValue(someValue);
答案 5 :(得分:0)
我在SList中发送IEnumerable而不是ViewBag
@Html.DropDownListFor(model => Model.list[i].Id, new SelectList(Model.SList, "Value", "Text", Model.list[i].Id), htmlAttributes: new { @class = "form-control" })