查看对应的函数方法,我们可以知道,DropDownListFor所需的参数为IEnumerable<SelectListItem>,所以我们在后台传入即可

情况一、数据是固定的
如果列表数据是固定的,建议使用ViewData[""]传递数据
下面是控制器的代码
public ActionResult UploadItem()
{
#region 物品类别集合
IEnumerable<SelectListItem> types = new List<SelectListItem>()
{
new SelectListItem(){ Text="网络设备",Value="网络设备" },
new SelectListItem(){ Text="电脑配件",Value="电脑配件" },
new SelectListItem(){ Text="图书画册",Value="图书画册" },
new SelectListItem(){ Text="电子产品",Value="电子产品" },
new SelectListItem(){ Text="其他",Value="其他",Selected=true } //Selected表示是否默认选中
};
ViewData["Type"] = types;
#endregion
return View();
}
使用这种方法时,使用时应该为ViewData[""] as IEnumerable<SelectListItem>
列子:
<div class="select-wrap select-wrap2">
@Html.DropDownListFor(t => t.TreasureType, ViewData["Type"] as IEnumerable<SelectListItem>, new { @class = "text_field" })
<span class="lnr lnr-chevron-down"></span>
</div>
情况二、数据是从数据库中读取的
这种情况,建议使用强视图类型,在原来的模型中添加对应属性
public class Treasure
{
......省略其他属性
//下拉框
public IEnumerable<SelectListItem> DropList { get; set; }
}
然后再视图中直接使用即可
<div class="select-wrap select-wrap2">
@Html.DropDownListFor(t => t.TreasureType,@Model.DropList, new { @class = "text_field" })
<span class="lnr lnr-chevron-down"></span>
</div>

本文详细介绍了在ASP.NET MVC中使用DropDownListFor方法的两种常见场景:固定数据列表和从数据库读取数据。通过具体代码示例,展示了如何在控制器中准备数据并传递给视图,以及如何在视图中正确使用这些数据。
231

被折叠的 条评论
为什么被折叠?



