亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

ASP.NET MVC實現下拉框多選

瀏覽:121日期:2022-06-08 18:15:33

我們知道,在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<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 citiesselect 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>拼接并呈現。

    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());    }}    }

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對的支持。如果你想了解更多相關內容請查看下面相關鏈接

標簽: ASP.NET
相關文章:
主站蜘蛛池模板: 伊人色综合琪琪久久社区 | 欧美在线观看一区二区三 | 精品国产一区二区三区四区色 | 国产特级全黄一级毛片不卡 | 婷婷综合缴情亚洲狠狠图片 | 日韩精品另类天天更新影院 | 国产成人精品三级 | 国产精品88| 欧亚精品一区二区三区 | 亚洲日韩欧美一区二区在线 | 欧美在线免费 | 最近手机中文在线视频 | 国内嫩模私拍精品视频 | 亚洲精品色综合久久久 | 伊人亚洲影院 | 高h喷水荡肉爽文np肉色文 | 唐人呦一呦xxxx视频 | 黄网站色在线视频免费观看 | 国产精品视频一区二区三区 | 在线观看免费网址大全 | 在线观看黄色一级片 | 日韩视频在线免费观看 | 高清在线一区 | 免费一区视频 | 99玖玖| www一级片| 欧美日韩一区二区三区四区在线观看 | 免费国内精品久久久久影院 | 丁香综合网 | 久草在线视频网站 | 再猛点深使劲爽日本免费视频 | 成年看片免费高清观看 | 国产日韩久久 | 免费观看日本人成影片 | 国产亚洲欧美在线 | 色琪琪原网站亚洲香蕉 | 国产亚洲一区二区三区不卡 | 国内外精品免费视频 | 日韩大片免费看 | 亚洲图欧美日韩色综合图 | 欧美日韩顶级毛片www免费看 |