如何在ASP.NETMVC中为DropDownListFor设置选中项-创新互联
这篇文章主要介绍“如何在ASP.NET MVC中为DropDownListFor设置选中项”,在日常操作中,相信很多人在如何在ASP.NET MVC中为DropDownListFor设置选中项问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何在ASP.NET MVC中为DropDownListFor设置选中项”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
网页设计是网站建设的前奏,好的网页设计更深度的剖析产品和设计风格定位,结合最新的网页设计流行趋势,与WVI应用标准,设计出具企业表现力,大器而深稳的网站界面设。创新互联建站从2013年开始,是成都网站建设公司:提供企业网站设计,品牌网站设计,营销型企业网站建设方案,响应式网站建设,微信小程序定制开发,专业建站公司做网站。在MVC中,当涉及到强类型编辑页,如果有select元素,需要根据当前Model的某个属性值,让Select的某项选中。本篇只整理思路,不涉及完整代码。
□ 思路
往前台视图传的类型是List
通过遍历List
□ 控制器
public ActionResult SomeAction(int id) { //从数据库获取Domain Model var domainModel = ModelService.LoadEntities(m => m.ID == id).FirstOrDefault(); //通过某个方法获取List 类型对象实例 List items = SomeMethod(); //遍历集合,如果当前Domain model的某个属性与SelectListItem的Value属性相等,把SelectListItem的Selected属性设置为true foreach(SelectListItem item in items) { if(item.Value == Convert.ToString(domainModel.某属性)) { item.Selected = true; } } //把List 集合对象实例放到ViewData中 ViewData["somekey"] = items; //可能涉及到把Domain Model转换成View Model return PartialView(domainModel); }
□ 前台视图显示
@model DomainModel
@Html.DropDownListFor(m => m.SomeProperty,(List
通过遍历Model集合
给View Model设置一个bool类型的字段,描述是否被选中。
把Model的某些属性作为SelectListItem的Text和Value值。根据View Model中的布尔属性判断是否要把SelectListItem的Selected设置为true.
□ View Model
public class Department { public int Id {get;set;} public string Name {get;set;} public bool IsSelected {get;set;} }
□ 控制器
public ActionResult Index() { SampleDbContext db = new SampleDbContext(); ListselectListItems = new List (); //遍历Department的集合 foreach(Department department in db.Departments) { SelectListItem = new SelectListItem { Text = department.Name, Value = department.Id.ToString(), Selected = department.IsSelected.HasValue ? department.IsSelected.Value : false } selectListItems.Add(selectListItem); } ViewBag.Departments = selectListItems; return View(); }
下面是其它网友的补充:
后台代码:
public ActionResult Index(FormCollection collection) { IListli = Utility.SqlHelper.getProjectList(); SelectList selec = new SelectList(li, "ID", "Name"); if (collection["drop"] != null) { string projectID = collection["drop"]; selec = new SelectList(li, "ID", "Name", projectID);//根据返回的选中项值设置选中项 ViewData["ruturned"] = collection["drop"]; } ViewData["drop"] = selec; return View(); }
前端代码:
@using (Html.BeginForm()){
@Html.DropDownList("drop", ViewData["d"] as SelectList)
}
当前项目ID: @ViewData["ruturned"]
到此,关于“如何在ASP.NET MVC中为DropDownListFor设置选中项”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!
分享文章:如何在ASP.NETMVC中为DropDownListFor设置选中项-创新互联
链接URL:http://myzitong.com/article/eppjs.html