如何在ASP.NET MVC模型中为POST保存选定的DropDownList值?

前端之家收集整理的这篇文章主要介绍了如何在ASP.NET MVC模型中为POST保存选定的DropDownList值?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的模型中有一个属性,如下所示:
  1. public IList<SelectListItem> AllCards { get; set; }

属性由控制器用来自数据库的数据填充SelectListItem.

此外,在我的视图中是@ Html.DropDownListFor(m => m.AllCards,Model.AllCards,“ – Select–”).
在POST视图期间出现问题.也就是说,onSubmit我的Model.AllCards是空的,尽管在下拉列表中选择了一个值.
我尝试将新属性添加到模型中,如下所示:

  1. public SelectListItem SelectedCard

然后像这样改变视图:

  1. @Html.DropDownListFor(m=>m.AllCards,Model.SelectedCard,"--Select--")

但它给了我一个错误,说转换不可能,就像那样.

我应该怎么做才能捕获我的dropdownlist值,以便在调用视图的POST版本后它可以在模型内部?
谢谢

附:我知道有十个类似的问题,但没有一个有用.

解决方法

我就是这样做的.

您的视图模型可能如下所示,并且会有一个卡片列表:

  1. public class Cardviewmodel
  2. {
  3. public int CardId { get; set; }
  4.  
  5. public IEnumerable<Card> Cards { get; set; }
  6. }

我不知道你的卡有什么属性,但让我发明自己的:

  1. public class Card
  2. {
  3. public int Id { get; set; }
  4.  
  5. public string Name { get; set; }
  6. }

您的视图将接受此视图模型:

  1. @model YourProject.viewmodels.Cards.Cardviewmodel

您的卡的HTML标记下拉列表:

  1. @Html.DropDownListFor(
  2. x => x.CardId,new SelectList(Model.Cards,"Id","Name",Model.CardId),"-- Select --",new { id = "Cards" }
  3. )
  4. @Html.ValidationMessageFor(x => x.CardId)

第一次加载视图时的操作方法

  1. public ActionResult YourActionMethod()
  2. {
  3. Cardviewmodel viewmodel = new Cardviewmodel
  4. {
  5. Cards = cardService.FindAll()
  6. }
  7.  
  8. return View(viewmodel);
  9. }
  10.  
  11. [HttpPost]
  12. public ActionResult YourActionMethod(Cardviewmodel viewmodel)
  13. {
  14. if (!ModelState.IsValid)
  15. {
  16. return View(viewmodel);
  17. }
  18.  
  19. // Do what ever you need to do. The selected card's id will now be populated
  20.  
  21. return RedirectToAction("List");
  22. }

关于你的JavaScript问题,我woudld建议你开始一个新的问题,但我会概述你可以注意什么.通过使用jQuery添加on change事件来分离您的JavaScript和HTML(使用您想要的任何内容).例如:

  1. <script>
  2.  
  3. $(document).ready(function () {
  4. $("#Cards").change(function () {
  5. alert('cards value has changed');
  6. });
  7. });
  8.  
  9. </script>

我希望这有帮助.

猜你在找的asp.Net相关文章