色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

ASP.NET MVC實(shí)現(xiàn)下拉框多選

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

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

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

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

當(dāng)按著ctrl鍵,進(jìn)行重新選擇多項(xiàng),點(diǎn)擊"提交"按鈕,把選中項(xiàng)的id拼接。

對于Select中的項(xiàng),包含顯示值,Value值,以及是否選中,抽象成如下的類。

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

對于整個(gè)多選Select來說,在ASP.NET MVC中,所有的選項(xiàng)被看作SelectListItem類型,選中的項(xiàng)是一個(gè)string類型的集合。于是多選Select的View Model設(shè)計(jì)為:

    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 = "濟(jì)南", 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中,是一個(gè)CityVm的強(qiáng)類型視圖,對于選中的項(xiàng)會以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("沒有選中任何選項(xiàng)");    }    else    {StringBuilder sb = new StringBuilder();sb.Append("選中項(xiàng)的Id是:" + string.Join(",", selectedCities));return Content(sb.ToString());    }}    }

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

標(biāo)簽: ASP.NET
相關(guān)文章:
主站蜘蛛池模板: 欧美特黄一级高清免费的香蕉 | 欧美激情一区二区亚洲专区 | 人人爽人人香蕉 | 波多野结衣中文在线 | 一区二区三区成人 | 国产精品二区高清在线 | 欧美成人亚洲欧美成人 | 久久成人免费播放网站 | 日韩美女在线看免费观看 | 免费国产成人高清在线看软件 | 波少野结衣在线播放 | 日韩一级大毛片欧美一级 | 狠狠色丁香婷婷综合 | 日本美女黄色一级片 | 欧美日韩视频一区二区在线观看 | www.欧美成人 | 午夜性爽快免费视频播放 | 欧美成人性色大片在线观看 | 国产三级三级三级 | 亚洲精品国产福利一区二区三区 | 国产色啪午夜免费视频 | 成人影院免费看 | 中文字幕亚洲欧美 | 欧美成人影院在线观看三级 | 一级大黄美女免费播放 | 欧美成人精品在线 | 免费午夜扒丝袜www在线看 | a级特黄毛片免费观看 | 国产欧美自拍 | 最近日本免费观看视频 | 宅男噜噜噜一区二区三区 | 美国免费一级片 | 精品久久久久久久久久中文字幕 | 亚洲国产成a人v在线观看 | 久久久国产99久久国产久 | 成人高清无遮挡免费视频软件 | 国产丝袜美女一区二区三区 | 国内精品久久久久久久久 | 亚洲男女在线 | 久草在线资源网站 | 五月色婷婷综合开心网亚 |