1

环境:带有 MVC 和 Razor 的实体框架 (v6.0)。后端是 SQL Server。

HTML 助手 DropDownListFor() 非常适合数据库中的字符串列。但是,当我使用带有数字下拉列表的小数列时,框架在呈现表单时不会选择从数据库加载的值。

我认为这与 DropDownListFor() 包含 Text 和 Value 的字符串这一事实有关,并且无法匹配数据库中的十进制值,因此未确定 SelectedItem。

我尝试在 HTML 帮助程序中进行强制转换,但在编译或运行时失败。我能找到的所有示例都假设您要选择一个字符串,而不是一个数字。

感激地收到任何帮助。谢谢。

查看代码:问题字段为CollarSize。下拉列表是 CollarSizeSelect。

<div class="form-group">
     @Html.LabelFor(model => model.CollarSize, htmlAttributes: new { @class = "control-label col-md-2" })
     <div class="col-md-10">
            @Html.DropDownListFor(model => model.CollarSize, Model.CollarSizeSelect, htmlAttributes: new { @class = "form-control" })
            @Html.ValidationMessageFor(model => model.CollarSize, "", new { @class = "text-danger" })
     </div>
</div>

类定义包含这样定义的列:

public Nullable<decimal> CollarSize { get; set; }

CollarSize 下拉列表构建如下:

public IEnumerable<SelectListItem> ChestSizeSelect
{
    get
    {
        return GetSelectNumberRange(32, 60, (decimal)1.0);
    }
}

private static List<SelectListItem> GetSelectNumberRange(int start, int end, decimal increment)
{
    List<SelectListItem> numlist = new List<SelectListItem>();
    for (decimal i = start; i <= end; i = i + increment)
    {
       numlist.Add(new SelectListItem() {Text = i.ToString(), Value = i.ToString()});
    }
    return numlist;
}
4

1 回答 1

1

问题不在于 SelectList 的构造,而在于底层数据库模式。

数据库栏:

CollarSize decimal(5, 2) NULL,

我使用实体框架从数据库构建模型(向导选项“数据库中的 EF 设计器”)。EF 在生成的模型中生成了字段:

public Nullable<decimal> CollarSize { get; set; }

我为填充 DropDownListFor() 生成的 SelectList 包含一个小数项列表,但这些项的精度为小数点后一位,即15.0M。但是,EF 保留了原始精度,因此当填充 DropDownList 时,无法找到 Selected 项,因为它将15.015.00进行比较。

我的解决方案是以明确的精度构建 SelectList:

public IEnumerable<SelectListItem> CollarSizeSelect
{
    get
    {
         return new SelectList(new List<decimal> { 14.00M, 14.50M, 15.00M, 15.50M...
    }
}
于 2015-08-04T13:01:56.720 回答