asp.net-mvc-3 – html.dropdownlist MVC3混乱

前端之家收集整理的这篇文章主要介绍了asp.net-mvc-3 – html.dropdownlist MVC3混乱前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
这对我有用,但我如何使用html.dropdownlist做同样的事情?

请注意,传递的值不是向用户显示的值.

  1. @model IEnumerable<MVR.Models.ViewIndividual>
  2.  
  3. <h2>Level1</h2>
  4. <select>
  5. @foreach (var item in Model) {
  6. <option value="@item.Case_Number">@item.Patient_Lastname,@item.Patient_Firstname
  7. </option>
  8. }
  9. </select>

解决方法

与ASP.NET MVC应用程序一样,您首先要定义视图模型:
  1. public class Myviewmodel
  2. {
  3. public string SelectedIndividual { get; set; }
  4. public SelectList Individuals { get; set; }
  5. }

然后你编写一个控制器动作,从一些数据源或其他东西填充这个视图模型:

  1. public ActionResult Index()
  2. {
  3. // TODO : fetch those from your repository
  4. var values = new[]
  5. {
  6. new { Value = "1",Text = "item 1" },new { Value = "2",Text = "item 2" },new { Value = "3",Text = "item 3" },};
  7.  
  8. var model = new Myviewmodel
  9. {
  10. Individuals = new SelectList(values,"Value","Text")
  11. };
  12. return View(model);
  13. }

最后你有一个使用强类型助手的强类型视图:

  1. @model Myviewmodel
  2. @Html.DropDownListFor(
  3. x => x.SelectedIndividual,Model.Individuals
  4. )

这就是说,因为我发现你没有在你的应用程序中使用任何视图模型,你总是可以尝试以下丑陋(不推荐,这需要你自己承担风险):

  1. @model IEnumerable<MVR.Models.ViewIndividual>
  2.  
  3. <h2>Level1</h2>
  4. @Html.DropDownList(
  5. "SelectedIndividual",new SelectList(
  6. Model.Select(
  7. x => new {
  8. Value = x.Case_Number,Text = string.Format(
  9. "{0},{1}",x.Patient_Lastname,x.Patient_Firstname
  10. )
  11. }
  12. ),"Text"
  13. )
  14. )

当然,这种色情内容不是我建议在视图中写的东西,我也不会向我最坏的敌人推荐.

结论:在ASP.NET MVC应用程序中,您应始终使用视图模型和强类型帮助程序的强类型视图(请参阅我的答案的第一部分).

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