25.1. Forms

As a user of the web, you know that web pages both display and accept data. In this chapter we are going to learn more about how web pages handle data input using HTML forms. An HTML form is used to accept input from the user and send that data to the server.

25.1.1. Create a Form

To declare a form in HTML use the <form> tag with open and closing tags. This form element will serve as container for various types of other elements that are designed to capture input from the user.

1
2
3
4
5
6
7
8
9
<html>
   <head>
      <title>Form Example</title>
   </head>
   <body>
      <!-- empty form -->
      <form></form>
   </body>
</html>

An empty <form></form> will not appear on a web page until inputs have been added inside of it. Below we have added one basic <input> tag.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
<html>
   <head>
      <title>Form Example</title>
   </head>
   <body>
      <form>
         <input type="text"/>
      </form>
   </body>
</html>

25.1.2. Input Element

The input element is used to add interactive fields, which allow the user to enter data. input elements have two very important attributes: name and type.

  • The name attribute is used to identify the input's value when the data is submitted

  • The type attribute defines which type of value of the input represents

<input type="text" name="username"/>

Note

Notice that <input type="text"/> tags are self closing. Self-closing tags are single tags with /> at the end.

Warning

Values are NOT submitted for an <input> unless it has a name attribute.

25.1.3. Labels

Forms normally contain more than one input. <label> tags are used to provide a textual label, which informs the user of the purpose of the field. The simplest usage of <label> tags is to wrap them around <input> tags.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
<html>
   <head>
      <title>Form Example</title>
   </head>
   <body>
      <form>
         <label>Username <input type="text" name="username"/></label>
         <label>Team Name <input type="text" name="team"/></label>
      </form>
   </body>
</html>
HTML that includes a form tag with two input elements. Each element is inside of a label element.

A second way to relate a <label> tag to an <input> is to use the id attribute of input and the for attribute of label. The two are related by setting for in <label for="username"> equal to the id of <input id="username">, these two attributes must be EQUAL. When for is used, the <input> does NOT have to be inside of the <label>.

1
2
<label for="username">Username</label>
<input id="username" name="username" type="text"/>

What happens when a <label> is clicked? The answer depends on what the <label> is associated to.

For text inputs, when the label is clicked, then the input gains focus. An element with focus is currently selected by the browser and ready to receive input.

Example

Try clicking on the Username and Team Name labels below. What happens?

1
2
3
4
<form>
   <label>Username <input type="text" name="username"/></label>
   <label>Team Name <input type="text" name="team"/></label>
</form>

For non-text inputs, when the label is clicked, a value is selected. This behavior can be seen with radio and checkbox elements which we will learn more about soon.

Example

Click on the label text to the associated checkbox input element gain focus.

1
2
3
4
5
<form>
   <label>Subscribe to Newsletter
      <input type="checkbox" name="newsletter"/>
   </label>
</form>

25.1.4. Value Attribute

The value attribute of an <input> tag can be used to set the default value. If the value attribute is declared, then the browser will show that value in the input. The user can choose to update the value by typing in the input box.

Example

Input with default value of JavaScript.

1
2
3
<form>
   <label>Language <input name="language" type="text" value="JavaScript"/></label>
</form>

25.1.5. Check Your Understanding

Question

What is the purpose of the name attribute for input elements?

Question

Which input attribute sets the default value?