Desafortunadamente no hay una sobrecarga incorporada de este asistente que le permita lograr esto.
Afortunadamente se necesitaría un par de líneas de código para implementar su propio:
public static class LabelExtensions
{
public static MvcHtmlString LabelFor<TModel, TValue>(
this HtmlHelper<TModel> html,
Expression<Func<TModel, TValue>> expression,
object htmlAttributes
)
{
return LabelHelper(
html,
ModelMetadata.FromLambdaExpression(expression, html.ViewData),
ExpressionHelper.GetExpressionText(expression),
htmlAttributes
);
}
private static MvcHtmlString LabelHelper(
HtmlHelper html,
ModelMetadata metadata,
string htmlFieldName,
object htmlAttributes
)
{
string resolvedLabelText = metadata.DisplayName ?? metadata.PropertyName ?? htmlFieldName.Split('.').Last();
if (string.IsNullOrEmpty(resolvedLabelText))
{
return MvcHtmlString.Empty;
}
TagBuilder tag = new TagBuilder("label");
tag.Attributes.Add("for", TagBuilder.CreateSanitizedId(html.ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldName(htmlFieldName)));
tag.MergeAttributes(new RouteValueDictionary(htmlAttributes));
tag.SetInnerText(resolvedLabelText);
return MvcHtmlString.Create(tag.ToString(TagRenderMode.Normal));
}
}
y una vez puesto en ámbito usar este helper en su opinión:
@Html.LabelFor(m => m.Foo, new { id = "Foo" })
@Html.TextBoxFor(m => m.Foo)
Observación: porque ahora Depende de usted administrar los ID de HTML, asegúrese de que sean únicos en todo el documento.
Remark2: plagio y modifico descaradamente el método LabelHelper
del código fuente de ASP.NET MVC 3.
¿por qué tiene que hacer m => m.Foo por qué no sólo m.Foo – Nikos
Porque tiene que insertar una expresión que se puede leer en lugar de insertar un valor. –