4

我对 MVC 还很陌生,想知道在我的编辑器模板中填充下拉列表的最佳方式?

我正在构建一个具有很多下拉列表的应用程序,并且这些下拉列表的数据是非常静态的。目前我将它们全部放在数据库中的一个表中,然后将它们加载到会话中。

这是一个例子:

我的观点:

   @{
        var widgettypes = Business.MySession.Current.WidgetTypes.ToSelectList(d => d.TypeName,
                                   d => d.WidgetTypeID.ToString(),
                                   " - Select - ");
    }
    <div class="editor-label">
        @Html.LabelFor(model => model.WidgetTypeID)
    </div>
    <div class="editor-field">
        @Html.DropDownListFor(model => model.WidgetTypeID, @widgettypes)
        @Html.ValidationMessageFor(model => model.WidgetTypeID)
    </div>

下拉助手:

    public static List<SelectListItem> ToSelectList<T>(
            this IEnumerable<T> enumerable,
            Func<T, string> text,
            Func<T, string> value,
            string defaultOption)
    {
        var items = enumerable.Select(f => new SelectListItem()
        {
            Text = text(f),
            Value = value(f)
        }).ToList();
        items.Insert(0, new SelectListItem()
        {
            Text = defaultOption,
            Value = "-1"
        });
        return items;
    }

我在 SO 上看到了很多示例,这些示例显示了在视图中静态创建选择列表。

最佳实践是从.net 代码中的静态枚举的视图中创建它们,还是最好按照我现在这样做的方式进行?或者它只是无关紧要?

我只想知道我应该做什么,而不是什么才有效。

4

1 回答 1

6

我个人认为数据库驱动是要走的路。主要是根据经验,假设您想在查找中添加一个值并且您已经部署了您的应用程序,您必须在将新值添加到 Enum 后重新部署代码。由于它们是数据库驱动的,您只需对数据库运行插入查询,无需重新部署。

我不会在你的视图中那样调用你的数据库,我不会说这是最佳实践,因为这不是视图的责任,它只需要显示数据,而不是查询额外的数据。

首先,将您想要的项目放在模型的下拉列表中,如下所示:

public class YourModel
{
    public int WidgetTypeId { get; set; }
    public SelectList WidgetTypes { get; set; }
    //...rest of your model
}

然后,在控制器中的 GET 方法中(在返回视图之前,使用视图中的代码填充该列表:

public ActionResult MyAction()
{
    YourModel model = new YourModel();

    model.WidgetTypes = Business.MySession.Current.WidgetTypes
        .ToSelectList(d => d.TypeName, d => d.WidgetTypeID.ToString(), " - Select - ");

    return View(model);
}

然后在您看来,只需执行以下操作:

@Html.DropDownListFor(model => model.WidgetTypeID, Model.WidgetTypes)
于 2013-01-12T20:04:18.843 回答