asp.net-mvc – DropDownList设置在asp.net MVC中选择项目

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – DropDownList设置在asp.net MVC中选择项目前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我注意到在我看来,一个错误在asp.net MVC或只是我做错了。我目前使用1.0,所以也许这是将在2.0版本中解决的。但无论如何,这里我们去。

当我的视图模型具有与下拉列表的声明的ID相同的属性时,所选项目被忽略,并且呈现的html没有选择。
不确定如果我做错了,但更改id的名称修复了问题。我简化了例子,希望很清楚,否则请让我知道。

这里是我的视图,其中声明的ID是与模型中的列表相同的名称

<table border="0" cellpadding="0" cellspacing="0">
   <tr>
      <td>
         <%= Html.DropDownList("IsMultipleServicers",Model.IsMultipleServicers) %>
      </td>
   </tr>
</table>

和渲染的Html

<table border="0" cellpadding="0" cellspacing="0">
      <tr>
         <td>
             <select id="IsMultipleServicers" name="IsMultipleServicers">
                <option value="false">No</option>
                <option value="true">Yes</option>
             </select>
         </td>
      </tr>
</table>

现在让我们做一个小的改变。我将更改声明的ID是不同的东西。

这里是我的视图:

<table border="0" cellpadding="0" cellspacing="0">
    <tr>
       <td>
          <%= Html.DropDownList("MultipleServicers",Model.IsMultipleServicers) %>
       </td>
    </tr>
</table>

现在渲染的html:

<table border="0" cellpadding="0" cellspacing="0">
   <tr>
      <td>
         <select id="IsMultipleServicers" name="IsMultipleServicers">
            <option value="false">No</option>
            <option selected="selected" value="true">Yes</option>
         </select>
      </td>
   </tr>
</table>

注意,现在我得到一个选择的选项,将是列表中的第二个元素。

这里是我的viewmodel只是把一切捆绑在一起:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;

namespace MVCProject.Models.viewmodels.Service
{
    public class Serviceviewmodel : viewmodel
    {
         public List<SelectListItem> IsMultipleServicers { get; set; }
    }
}

这里是我的行动:

[AcceptVerbs(HttpVerbs.Get)]
public virtual ActionResult Service()
{
   return View(new Serviceviewmodel()
   {
      IsMultipleServicers = BuildBooleanSelectList(true)
   };
}

 private List<SelectListItem> BuildBooleanSelectList(bool isTrue)
 {
    List<SelectListItem> list = new List<SelectListItem>();

    if (isTrue)
    {
       list.Add(new SelectListItem() { Selected = false,Text = "No",Value = "false" });
       list.Add(new SelectListItem() { Selected = true,Text = "Yes",Value = "true" });
    }
    else
    {
       list.Add(new SelectListItem() { Selected = true,Value = "false" });
       list.Add(new SelectListItem() { Selected = false,Value = "true" });
    }
 return list;
  }

解决方法

我认为问题是关于DropDownList重载的混乱:

> Html.DropDownList(string name)查找名为和IEnumerable< SelectListItem>类型的视图模型属性。它将使用从列表中选择的项目(SelectListItem.Selected == true),除非有相同名称的表单后置值。
> Html.DropDownList(string name,IEnumerable< SelectListItem> selectList)使用selectList中的项,而不是它们选择的值。通过在视图模型(或发布数据)中解析名称并将其与SelectListItem.Value进行匹配,找到所选的。即使找不到该值(或为null),它仍然不会使用SelectListItems列表中的选定值。

您的代码使用第二个重载,但指定一个“value”属性不存在(“MultipleServicers”)。

解决您的问题,请使用第一个重载:

<%= Html.DropDownList("IsMultipleServicers") %>

或者,为您的视图模型添加一个字符串MultipleServicers属性,并将其填充到控制器中。我建议这个解决方案,因为它遇到了几个问题,初始显示,后显示和映射后的数据到视图/后模型:

public class Serviceviewmodel : viewmodel 
{ 
     public string MultipleServicers { get; set; } 
     public List<SelectListItem> IsMultipleServicers { get; set; } 
}

然后为您的HTML:

<%= Html.DropDownList(Model.MultipleServicers,Model.IsMultipleServicers) %>

这种技术也映射到MVC2:

<%= Html.DropDownListFor(x => x.MultipleServicers,Model.IsMultipleServicers) %>

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