奇怪的下拉列表/选择列表项问题未设置默认值

本文关键字:问题 设置 默认值 列表 选择 下拉列表 | 更新日期: 2023-09-27 17:56:19

我在这里拔头发。我在 MVC3 中使用带有枚举的 DropDownListFor HTML 帮助程序,如下所示:

@Html.DropDownListFor(model => model.Title, Enum.GetValues(typeof(ICS_Signup_Form.Models.Titles)).Cast<ICS_Signup_Form.Models.Titles>().Select(x => new SelectListItem { Text = x.ToString().ToFriendlyString(), Value = x.ToString() }), new { @class = "styled" })

我的枚举如下所示:public enum Titles { Mr, Dr, Miss, Mrs, Ms, Other };

如果Model.Title等于"其他",则下拉列表不会选择此值,HTML 中没有selected="selected"。我尝试将属性Selected添加到 SelectListItemSelected = (x.ToString() == Model.Title) 并且表达式在我按预期单步执行代码时工作正常,但所选值始终为"Mr"(列表中的第一个)。

更奇怪的是,这工作得很好(就像我项目中的其他 7 个下拉框一样):

@Html.DropDownListFor(model => model.BusinessStatus, Enum.GetValues(typeof(ICS_Signup_Form.Models.BusinessTypes)).Cast<ICS_Signup_Form.Models.BusinessTypes>().Select(x => new SelectListItem { Text = x.ToString().ToFriendlyString(), Value = x.ToString() }), new { @class = "styled" })

使用枚举:public enum BusinessTypes { Charity, Government, Limited, LLP, Partnership, PLC, SoleTrader };

区别?没有。。有什么想法吗?

奇怪的下拉列表/选择列表项问题未设置默认值

tldr;将 DropDownList 的名称更改为其他名称

我遇到了同样的问题(尽管在ASPX引擎中,但我认为在这种情况下没有任何区别)。 重现方法如下:

代码隐藏(注意第二项中的"选定 = true"):

List<SelectListItem> teams = new List<SelectListItem>();
teams.Add(new SelectListItem { Text = "Slackers", Selected = false, Value = "0" });
teams.Add(new SelectListItem { Text = "Workers", Selected = true, Value = "1" });
ViewData["teams"] = teams;

ASPX 代码:

<%: Html.DropDownList("team", (IEnumerable<SelectListItem>)ViewData["teams"]) %>

它重现:您可以看到第一个项目被自动选中,并且两个项目都没有 HTML 中的"选择"选项。 这是生成的 HTML 来重现它:

<select id="team" name="team">
<option value="0">Slackers</option>
<option value="1">Workers</option>
</select>

解决方案:事实证明,某些元素名称会导致 ASPX 呈现引擎的行为不同。 就我而言,我只是将DropDownList名称从"team"更改为"defaultteam" - 它开始工作:

这是工作 ASPX 代码:

<%: Html.DropDownList("defaultteam", (IEnumerable<SelectListItem>)ViewData["teams"]) %>

这是它生成的 HTML:

<select id="defaultteam" name="defaultteam">
<option value="0">Slackers</option>
<option selected="selected" value="1">Workers</option>
</select>

这很奇怪。我无法重现。这是我的工作代码。

型:

public enum Titles { Mr, Dr, Miss, Mrs, Ms, Other };
public class MyViewModel
{
    public Titles Title { get; set; }
}

控制器:

public class HomeController : Controller
{
    public ActionResult Index()
    {
        var model = new MyViewModel
        {
            Title = Titles.Other
        };
        return View(model);
    }
}

视图:

@model MyViewModel
@Html.DropDownListFor(
    model => model.Title, 
    Enum.GetValues(typeof(Titles))
        .Cast<Titles>()
        .Select(x => new SelectListItem 
        { 
            Text = x.ToString(), 
            Value = x.ToString() 
        }), 
    new { @class = "styled" }
)

正如预期的那样,Other是预先选择的:

<select class="styled" id="Title" name="Title">
    <option value="Mr">Mr</option>
    <option value="Dr">Dr</option>
    <option value="Miss">Miss</option>
    <option value="Mrs">Mrs</option>
    <option value="Ms">Ms</option>
    <option selected="selected" value="Other">Other</option>
</select>

您可能还会发现以下扩展方法很有用。