日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

在ASP.NET MVC中实现Select多选

發(fā)布時間:2023/12/10 asp.net 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 在ASP.NET MVC中实现Select多选 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

我們知道,在ASP.NET MVC中實現(xiàn)多選Select的話,使用Html.ListBoxFor或Html.ListBox方法就可以。在實際應(yīng)用中,到底該如何設(shè)計View Model, 控制器如何接收多選Select的選中項呢?

?

實現(xiàn)效果如下:

初始狀態(tài)某些選項被選中。

?

當按著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設(shè)計為:

?

public class CityVm { public IEnumerable<SelectListItem> Cities { get; set; } public IEnumerable<string> SelectedCities { get; set; } }

?

在HomeController中,把SelectListItem的集合賦值給CityVm的Cities屬性。

?

public class HomeController : Controller { public ActionResult Index() { var cities = new List<City> { 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"; } <h2>Index</h2> @using (Html.BeginForm("GetCities", "Home", FormMethod.Post, new {id = "myForm"})) { @Html.ListBoxFor(c => c.SelectedCities, Model.Cities, new {size = ViewData["cc"]}) <br/> <input type="submit" value="提交"/> }

?

在HomeController中,再把從視圖傳遞過來的IEnumerable<string>拼接并呈現(xiàn)。

?

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

轉(zhuǎn)載于:https://www.cnblogs.com/darrenji/p/4377157.html

總結(jié)

以上是生活随笔為你收集整理的在ASP.NET MVC中实现Select多选的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。