微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net – DropDownList的EditorTemplate

我为字符串字段创建了一个EditorTemplate,它实现了bootstrap,如下所示:
@using MyProject
@model object
<div class="form-group">
    @Html.LabelFor(m => m,new { @class = "col-md-3 control-label" })
    <div class="col-md-9">
        @Html.TextBox(
            "",ViewData.TemplateInfo.FormattedModelValue,htmlAttributes)
        @Html.ValidationMessageFor(m => m,null,new { @class = "help-block" })
    </div>
</div>

我可以这样简单地称之为:

@Html.EditorFor(model => model.FirstName,"BootstrapString")

我的问题:
我如何为DropDownList执行此操作,以便我只能调用@ Html.EditorFor,如下所示:

@Html.EditorFor(model => model.CategoryId,new SelectList(ViewBag.Categories,"ID","CategoryName"))

所以它基本上是一个带有Twitter Bootstrap样式的Generic DropDownList.

解决方法

选项1

创建一个名为BootstrapSelect.cshtml的EditorTemplate

@model object
<div class="form-group">
  @Html.LabelFor(m => m,new { @class = "col-md-3 control-label" })
  <div class="col-md-9">
    @Html.DropDownListFor(m => m,(SelectList)ViewBag.Items,new { @class = "form-control"})
    @Html.ValidationMessageFor(m => m,new { @class = "help-block" })      
  </div>
</div>

并在视图中

@Html.EditorFor(m => m.CategoryId,"BootstrapSelect")

但这意味着你总是需要在控制器中分配`ViewBag.Items

var categories = // get collection from somewhere
ViewBag.Items = new SelectList(categories,"CategoryName");

选项2

修改EditorTemplate以接受其他ViewData

@model object
<div class="form-group">
  @Html.LabelFor(m => m,(SelectList)ViewData["selectList"],new { @class = "help-block" })      
  </div>
</div>

并在视图中传递additionalViewData参数中的SelectList

@Html.EditorFor(m => m.CategoryId,"BootstrapSelect",new { selectList = new SelectList(ViewBag.Categories,"CategoryName") })

这是更好的,因为您不需要依赖ViewBag.例如,如果您有一个带有属性的视图模型public SelectList CategoryItems {get;组;然后你可以使用

@Html.EditorFor(m => m.CategoryId,Model.CategoryItems)

选项3

使用内置的帮助器方法创建自己的帮助器

using System;
using System.Linq.Expressions;
using System.Text;
using System.Web.Mvc;
using System.Web.Mvc.Html;

namespace YourAssembly.Html
{
  public static class BootstrapHelper
  {
    public static MvcHtmlString BootstrapDropDownFor<TModel,TValue>(this HtmlHelper<TModel> helper,Expression<Func<TModel,TValue>> expression,SelectList selectList)
    {      
      MvcHtmlString label = LabelExtensions.LabelFor(helper,expression,new { @class = "col-md-3 control-label" });
      MvcHtmlString select = SelectExtensions.DropDownListFor(helper,selectList,new { @class = "form-control" });
      MvcHtmlString validation = ValidationExtensions.ValidationMessageFor(helper,new { @class = "help-block" });
      StringBuilder innerHtml = new StringBuilder();
      innerHtml.Append(select);
      innerHtml.Append(validation);
      TagBuilder innerDiv = new TagBuilder("div");
      innerDiv.AddCssClass("col-md-9");
      innerDiv.InnerHtml = innerHtml.ToString();
      StringBuilder outerHtml = new StringBuilder();
      outerHtml.Append(label);
      outerHtml.Append(innerDiv.ToString());
      TagBuilder outerDiv = new TagBuilder("div");
      outerDiv.AddCssClass("form-group");
      outerDiv.InnerHtml = outerHtml.ToString();
      return MvcHtmlString.Create(outerDiv.ToString());
    }
  }
}

并在视图中

@Html.BootstrapDropDownFor(m => m.CategoryId,"CategoryName"))

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


这篇文章主要讲解了“WPF如何实现带筛选功能的DataGrid”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“WPF...
本篇内容介绍了“基于WPF如何实现3D画廊动画效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这...
Some samples are below for ASP.Net web form controls:(from http://www.visualize.uk.com/resources/asp
问题描述: 对于未定义为 System.String 的列,唯一有效的值是(引发异常)。 For columns not defined as System.String, the only vali
最近用到了CalendarExtender,结果不知道为什么发生了错位,如图在Google和百度上找了很久,中文的文章里面似乎只提到了如何本地化(就是显示中文的月份)以及怎么解决被下拉框挡住的问题,谈
ASP.NET 2.0 page lifecyle ASP.NET 2.0 event sequence changed a lot since 1.1. Here is the order: App
静态声明: &#39; Style=&quot;position: relative&quot; AppendDataBoundItems=&quot;True&quot;&gt; (无 或 空 或
以下内容是从网络上搜集资料,然后整理而来的。不当之处,请不吝指教。(The following were from network, and edited by myself. Thanks in a
Imports System Imports System.Reflection Namespace DotNetNuke &#39;*********************************
Ok so you have all seen them: “8 million tools for web development”, “5 gagillion tools that if you