MVC中DropDownListFor赋初始选择值问题

本文介绍了在ASP.NET MVC中使用DropDownListFor时遇到的初始选择值无法自动绑定的问题。当ViewData和ViewBag中Key相同导致数据绑定冲突时,可以通过更改ViewData的Key来避免这个问题,确保每个DDLFor有独特的Key,从而正确显示数据库中的对应数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、基本数据绑定


View部分:

            @Html.DropDownListFor(model => model.Company_ID, ViewData["Company_ID"] as IEnumerable<SelectListItem>, "--Select One--")
            @Html.DropDownListFor(model => model.Company_ID, ViewBag.List as IEnumerable<SelectListItem>, "--Select One--")
Control部分:


            List<SelectListItem> cmpyID = new List<SelectListItem>();
            foreach (var it in db.Companies)
            {
                cmpyID.Add(new SelectListItem { Text = it.Name, Value = it.ID.ToString(), Selected = (it.ID == user.Company_ID) });
            }
            //ViewData["Company_ID"] = cmpyID;
            ViewBag.List = cmpyID;


二、从数据库中读取数据后,让DDLF自动选择对应数据.

            List<SelectListItem> cmpyID = new List<SelectListItem>();
            foreach (var it in db.Companies)
            {
                cmpyID.Add(new SelectListItem { Text = it.Name, Value = it.ID.ToString(), Selected = (it.ID == user.Company_ID) });
            }
            //ViewData["Company_ID"] = cmpyID;
            ViewBag.List = cmpyID;

创建SelectListItem的时候加上Selected字段就可以了。


三、存在的问题

    利用ViewData的方式会出现无法自动绑定选择数据库中对应的数据,同一个View中有两个DDLF,都使用ViewData的方式绑定数据,其中一个可以完成想要的效果,另外一个不能,后来讲不行的改成ViewBag方式就可以了.

原因:

关键的Key = Company_ID 值相同,这个时候在绑定选择的时候就有问题了,需要将ViewData中的关键字顶一个其他的不重复的名称就可以了。如下,

@Html.DropDownListFor(model => model.Company_ID, ViewData["Company_ID"] as IEnumerable<SelectListItem>, "--Select One--")
修改为
<pre name="code" class="html">@Html.DropDownListFor(model => model.Company_ID, ViewData["CompanyIDData"] as IEnumerable<SelectListItem>, "--Select One--")



四、效果图




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值