2010-04-07 25 views
8

Tengo el siguienteAsp.net MVC Etiqueta Para

<label for="Forename">Forename</label> 
<%= Html.TextBoxFor(m => m.Customer.Name.Forename) %> 

el problema con esto es que esto se representa como

<label for="Forename">Forename</label> 
<input type="text" value="" name="Customer.Name.Forename" id="Customer_Name_Forename"> 

no lo que yo quiero OFC.

Me gustaría una extensión para representar la etiqueta correctamente (es decir, con el atributo for = "" que tiene el valor de la identificación de entrada), ¿hay algo en MVC 2 que lo haga nativamente antes de escribir mi propia extensión?

Respuesta

13
<%= Html.LabelFor(m => m.Customer.Name.Forename) %> 
<%= Html.TextBoxFor(m => m.Customer.Name.Forename) %> 
11

A continuación se permite anular el nombre de visualización predeterminada, la alternativa a usar el siguiente es destrozar el modelo mediante un atributo [DisplayName]

Uso

<%= Html.LabelFor(m => m.Customer.Name.Forename, "First Name")%> 

Código

namespace System.Web.Mvc.Html 
{ 
    public static class LabelExtensions 
    { 
     public static MvcHtmlString LabelFor<TModel, TValue>(this HtmlHelper<TModel> html, Expression<Func<TModel, TValue>> expression, string displayName) 
     { 
      return LabelHelper(html, ModelMetadata.FromLambdaExpression<TModel, TValue>(expression, html.ViewData), ExpressionHelper.GetExpressionText(expression), displayName); 
     } 

     internal static MvcHtmlString LabelHelper(HtmlHelper html, ModelMetadata metadata, string htmlFieldName, string displayName) 
     { 
      string str = displayName ?? metadata.DisplayName ?? (metadata.PropertyName ?? htmlFieldName.Split(new char[] { '.' }).Last<string>()); 
      if (string.IsNullOrEmpty(str)) 
      { 
       return MvcHtmlString.Empty; 
      } 
      TagBuilder builder = new TagBuilder("label"); 
      builder.Attributes.Add("for", html.ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldId(htmlFieldName)); 
      builder.SetInnerText(str); 
      return MvcHtmlString.Create(builder.ToString(TagRenderMode.Normal)); 
     } 
    } 
} 
+0

Apreciar el código s nippet =) – afreeland

+0

"vandalize su modelo usando un atributo [DisplayName]" - lol – Alex

+0

@Alex Oh sí, esta fue una idea terrible, buen trabajo que conozco mejor 4 años y medio después. –