Как указать идентификатор для Html.LabelFor <> (MVC Razor)

Возможный дубликат:
Идентификатор клиента для свойства (ASP.Net MVC)

Есть ли способ сделать Razor рендерингом атрибута ID для элемента Label при использовании Html.LabelFor < > helper?

Пример:

.cshtml page
@using (Html.BeginForm())
{
@Html.LabelFor(m => m.Foo)
@Html.TextBoxFor(m => m.Foo)
}

Страница рендеринга

<form ...>
<label for="Foo" id="Label_Foo" />
<input type="text" name="Foo" id="Foo" />
</form>

FYI. Единственная причина, по которой я хочу добавить идентификатор в Label, - это дизайн CSS. Я бы предпочел ссылаться на метку с помощью идентификатора, а не на обертку ярлыка внутри блока (т.е. Div), а затем стилизовать блок.

Ответы

Ответ 1

К сожалению, встроенная перегрузка этого помощника не позволяет вам этого добиться.

К счастью, для реализации собственного кода потребуется несколько строк кода:

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));
    }
}

и как только вы ввели в поле зрения, используйте этот помощник в своем представлении:

@Html.LabelFor(m => m.Foo, new { id = "Foo" })
@Html.TextBoxFor(m => m.Foo)

Примечание: поскольку теперь вам нужно управлять идентификаторами HTML, убедитесь, что они уникальны во всем документе.

Замечание2: Я бесстыдно плагиат и модифицировал метод LabelHelper из исходного кода ASP.NET MVC 3.

Ответ 2

и для нормальной метки @Html.Label()

вы можете сделать это и сделать простой код с одной строкой...

public static HtmlString Label(this HtmlHelper helper, string target = "", string text = "", string id = "")
{
    return new HtmlString(string.Format("<label id='{0}' for='{1}'>{2}</label>", id, target, text));
}