Tuesday, April 21, 2015

MVC - HTML Helpers few more examples

HTML Helpers

Let us see some examples on HTML helpers
Suppose, to produce the HTML for a textbox with id="username" and name="username", we can type all the html in the view as shown below
<input type="text" name="username" id="username" />

OR

We can use the "TextBox" html helper. 
@Html.TextBox("username") 



There are several overloaded versions. To set a value, along with the name, use the following overloaded version.
@Html.TextBox("username", "John")

The above html helper, generates the following HTML
<input id="username" name="username" type="text" value="Juvenile" />

To set HTML attributes, use the following overloaded version. Notice that, we are passing HTML attributes (style title) as an anonymous type.
@Html.TextBox("username", "John", new { style = "background-color:Red; color:White; font-weight:bold", title="Please enter your user name" })
Some of the html attributes, are reserved keywords. Examples include class, readonlyetc. To use these attributes, use "@" symbol as shown below.
@Html.TextBox("username""John"new { @class = "redtextbox", @readonly="true" })

To generate a label for "User Name"
@Html.Label("username""User Name")

To generate a textbox to enter password, so that the input is masked
@Html.Password("Password")

To generate a multi-line textbox with 5 rows and 20 columns
@Html.TextArea("Description""", 10, 30, null)

To generate a hidden textbox
@Html.Hidden("Empid")

Hidden textbox is used to store id values. Id values are not displayed on the page to the end user, but we need them to update data when the form is posted to the server.

Is it possible to create our own custom html helpers?
Yes, we will discuss this in a later video session.

Is it mandatory to use HTML helpers?
No, you can type the required HTML, but using HTML helpers will greatly reduce the amount of HTML that we have to write in a view. Views should be as simple as possible. All the complicated logic to generate a control can be encapsulated into the helper, to keep views simple. 

No comments:

Post a Comment