asp.net - 如何在 ASP.NET MVC 模型中保存选定的 DropDownList 值以进行 POST?

标签 asp.net asp.net-mvc asp.net-mvc-3 asp.net-mvc-4 razor

我的模型中有一个属性,如下所示:

 public IList<SelectListItem> AllCards { get; set; }

Controller 正在使用数据库中的数据填充 SelectListItem 的属性。

另外,在我的 View 中是@Html.DropDownListFor(m=>m.AllCards,Model.AllCards,"--Select--")。 发布 View 期间出现问题。也就是说,尽管在下拉列表中选择了一个值,但 onSubmit my Model.AllCards 为空。 我尝试向模型添加一个新属性,如下所示:

public SelectListItem SelectedCard

然后像这样更改 View :

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

但它给了我一个错误,说不可能进行转换,诸如此类。

我应该怎么做才能捕获我的下拉列表值,以便在调用 View 的 POST 版本后它可以位于模型内部? 谢谢

附注我知道有十个类似的问题,但没有一个有帮助。

最佳答案

我本来就是这样做的。

您的 View 模型可能如下所示,并且将包含一个卡片列表:

public class CardViewModel
{
     public int CardId { get; set; }

     public IEnumerable<Card> Cards { get; set; }
}

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

public class Card
{
     public int Id { get; set; }

     public string Name { get; set; }
}

您的 View 将接受此 View 模型:

@model YourProject.ViewModels.Cards.CardViewModel

卡片下拉列表的 HTML 标记:

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

第一次加载 View 时的操作方法:

public ActionResult YourActionMethod()
{
     CardViewModel viewModel = new CardViewModel
     {
          Cards = cardService.FindAll()
     }

     return View(viewModel);
}

[HttpPost]
public ActionResult YourActionMethod(CardViewModel viewModel)
{
     if (!ModelState.IsValid)
     {
          return View(viewModel);
     }

     // Do what ever you need to do. The selected card's id will now be populated

     return RedirectToAction("List");
}

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

<script>

     $(document).ready(function () {
          $("#Cards").change(function () {
               alert('cards value has changed');
          });
     });

</script>

我希望这会有所帮助。

关于asp.net - 如何在 ASP.NET MVC 模型中保存选定的 DropDownList 值以进行 POST?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17555241/

相关文章:

asp.net-mvc-3 - 在 chtml 页面中使用 UrlHelper 扩展而不引用

c# - 为什么在 View 中检查 null 时会出现 NullReferenceException

javascript - 我需要有关从 ASP 下拉列表中设置值的帮助

部分 View 中的 javascript 未触发

asp.net - 使 IIS 不将页面呈现为 WML。曾经!

javascript - JQuery UI 自动完成功能在 MVC View 中不起作用

ASP.NET MVC - 在哪里放置数据库查询

c# - 下拉菜单始终处于事件状态并显示

c# - ASP.NET MVC : 'Extend' Html. TextBox 有条件地具有 CSS 值?

json - ASP.NET MVC : Specify value provider on a per-action or per-route basis?