博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在ASP.NET MVC中实现Select多选
阅读量:5128 次
发布时间:2019-06-13

本文共 2056 字,大约阅读时间需要 6 分钟。

我们知道,在ASP.NET MVC中实现多选Select的话,使用Html.ListBoxFor或Html.ListBox方法就可以。在实际应用中,到底该如何设计View Model, 控制器如何接收多选Select的选中项呢?

 

实现效果如下:

初始状态某些选项被选中。

 

当按着ctrl键,进行重新选择多项,点击"提交"按钮,把选中项的id拼接。

 

对于Select中的项,包含显示值,Value值,以及是否选中,抽象成如下的类。

 

 
public class City
{
public int Id { get; set; }
public string Name { get; set; }
public bool IsSelected { get; set; }
}

 

对于整个多选Select来说,在ASP.NET MVC中,所有的选项被看作SelectListItem类型,选中的项是一个string类型的集合。于是多选Select的View Model设计为:

 

 
public class CityVm
{
public IEnumerable
Cities { get; set; }
public IEnumerable
SelectedCities { get; set; }
}

 

在HomeController中,把SelectListItem的集合赋值给CityVm的Cities属性。

 

 
public class HomeController : Controller
{
public ActionResult Index()
{
var cities = new List
{
new City(){Id = 1, Name = "青岛", IsSelected = true},
new City(){Id = 2, Name = "胶南", IsSelected = false},
new City(){Id = 3, Name = "即墨", IsSelected = true},
new City(){Id = 4, Name = "黄岛", IsSelected = false},
new City(){Id = 5, Name = "济南", IsSelected = false}
};
 
var citiesToPass = from c in cities
select new SelectListItem() {Text = c.Name, Value = c.Id.ToString(),Selected = c.IsSelected};
 
CityVm cityVm = new CityVm();
cityVm.Cities = citiesToPass;
 
ViewData["cc"] = citiesToPass.Count();
 
return View(cityVm);
}
 
......
 
}
 
 

 

在Home/Index.cshtml中,是一个CityVm的强类型视图,对于选中的项会以IEnumerable<string>集合传递给控制器。

 

 
@model MvcApplication1.Models.CityVm
 
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_Layout.cshtml";
}
 

Index

@using (Html.BeginForm("GetCities", "Home", FormMethod.Post, new {id = "myForm"}))
{
@Html.ListBoxFor(c => c.SelectedCities, Model.Cities, new {size = ViewData["cc"]})
}
 
 

 

在HomeController中,再把从视图传递过来的IEnumerable<string>拼接并呈现。

 

 
public class HomeController : Controller
{
......
 
[HttpPost]
public ActionResult GetCities(IEnumerable
selectedCities)
{
if (selectedCities == null)
{
return Content("没有选中任何选项");
}
else
{
StringBuilder sb = new StringBuilder();
sb.Append("选中项的Id是:" + string.Join(",", selectedCities));
return Content(sb.ToString());
}
}
 
}
 

转载于:https://www.cnblogs.com/darrenji/p/4377157.html

你可能感兴趣的文章
python目录
查看>>
django+uwsgi+nginx+sqlite3部署+screen
查看>>
Andriod小型管理系统(Activity,SQLite库操作,ListView操作)(源代码下载)
查看>>
在Server上得到数据组装成HTML后导出到Excel。两种方法。
查看>>
浅谈项目需求变更管理
查看>>
经典算法系列一-快速排序
查看>>
设置java web工程中默认访问首页的几种方式
查看>>
ASP.NET MVC 拓展ViewResult实现word文档下载
查看>>
8、RDD持久化
查看>>
第二次团队冲刺--2
查看>>
VMware Tools安装
查看>>
Linux上架设boost的安装及配置过程
查看>>
[转载]加密算法库Crypto——nodejs中间件系列
查看>>
zoj 2286 Sum of Divisors
查看>>
使用Xshell密钥认证机制远程登录Linux
查看>>
OpenCV之响应鼠标(三):响应鼠标信息
查看>>
Android 画图之 Matrix(一)
查看>>
List<T>列表通用过滤模块设计
查看>>
【模板】最小生成树
查看>>
设计模式之结构型模式
查看>>