22

I'm trying to do a label for a TextBox in my View and I'd like to know, how can I take a Id that will be render in client to generate scripts... for example:

<label for="<%=x.Name.ClientId%>"> Name: </label>
<%=Html.TextBoxFor(x=>x.Name) %>

What do I need to put in "ClientId" to make sure that the correct Id will be rendered to the corresponding control?

Fred
  • 3,365
  • 4
  • 36
  • 57
Felipe Oriani
  • 37,948
  • 19
  • 131
  • 194

5 Answers5

38

Put this code somewhere:

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

namespace MvcLibrary.Extensions 
{ 
    public static class HtmlExtensions 
    { 
        public static MvcHtmlString FieldIdFor<TModel, TValue>(this HtmlHelper<TModel> html,
            Expression<Func<TModel, TValue>> expression) 
        { 
            string htmlFieldName = ExpressionHelper.GetExpressionText(expression); 
            string inputFieldId = html.ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldId(htmlFieldName); 
            return MvcHtmlString.Create(inputFieldId); 
        } 
    } 
}

Then in your ASPX view:

<label for="<%= Html.FieldIdFor(m => m.EmailAddress) %>">E-mail address:</label> 
<%= Html.TextBoxFor(m => m.EmailAddress) %>

You can also use this in JavaScript calls as you won't know the control's ID in advance and may need it for some JavaScript code to work against it:

<script> $.CoolJQueryFunction('<%= Html.FieldIdFor(m => m.EmailAddress) %>'); </script>

The LabelFor HTML helper method, that someone mentioned here, won't let you specify the actual text label you want to use, you have to decorate your ViewModels with attributes to set the label text, with IMHO is ugly. I'd rather that stuff appear in the actual ASPX view part itself, not on some domain/view model. Some people will disagree with me though.

Not sure of the rules for posting links to one's blog posts, but I posted a blog on this exact topic: http://www.dominicpettifer.co.uk/Blog/37/strongly-typed--label--elements-in-asp-net-mvc-2

Sunday Ironfoot
  • 12,840
  • 15
  • 75
  • 91
  • I know, but some people can't understand correctly (my english isn't very well)! That's all I need... Thanks a lot Man! Decorate domain model classes with attributies isn't a good pratice for me, I agree with you! – Felipe Oriani Jun 18 '10 at 13:30
  • See my answer below this is no longer required – Daniel Powell Jan 21 '13 at 06:14
27

MVC 4 has this built in now.. see this

Daniel Powell
  • 8,143
  • 11
  • 61
  • 108
7

Its fun what can be found at free source code of MVC. Here is the answer:

@Html.IdFor or @Html.NameFor

So what is the difference? Here is the catch:

The NameFor would not replace any "." to "_".

If you want any example, I have found this cool small article

0

As has been said, you don't need to worry about ClientID, UniqueID etc in ASP.NET MVC as those are webforms abstractions. You can simply just write out the ID that you want. There is also an extension method for this:

<%= Html.LabelFor(x => x.Name) %>
richeym
  • 4,049
  • 3
  • 24
  • 23
  • 1
    LabelFor will give you a strongly typed – Sunday Ironfoot Jun 18 '10 at 13:20
-2

Use the following:

Model.Name

You can simply do a "view source" or examine the rendered textbox with something like Firebug to see what the Html.xyzFor() methods are generating. Normally they would generate a textbox with the "id" and "name" attributes both set to the property name.

womp
  • 115,835
  • 26
  • 236
  • 269
  • it'll write the content of the property, and I don't need it.. i need the Name of the Property (or Client Id... if there is one... i don't know excatly) – Felipe Oriani Jun 17 '10 at 20:22
  • @FelipeOriani @womp while using `Html.LabelFor(x => x.Id)` it is showing me the "Id" Text which i defined `DisplayName` of Id instead of Id value which is coming from DB. Any comments? – Steve Jul 20 '16 at 06:06