HTML FORMS
HAFIZ ABDUL MANNAN
Forms
Creating a Form
Form Attributes
Forms Controls
Example of Contact Form
Creating Labels
Structuring Your Forms
Focus
Disabled and Read - Only Controls
Sending Form Data to the Server
What is Form?
Collect information from a visitor
Forms are made up of areas to enter text, boxes to
check (or tick), options to choose from, and so on.
On the Web you can create a form by form
controls , such as textboxes, checkboxes, select
boxes and radio buttons
Any form that you create will live inside an
element called <form >
Once users have entered information into a form,
they usually have to click what is known as a
submit button
HTML Forms
HTML forms are used <form>
to collect user input. .
The <form> element form elements
defines an HTML .
form: </form>
Forms Elements
HTML forms contain form elements.
Form elements are different types of input
elements:
checkboxes
radio buttons
submit buttons, and more.
<Input> Element
The <input> element Type Description
is the most Text Defines normal
text input
important form
Radio Defines radio
element. button input
The <input> element (for selecting
one of many
has many variations, choices)
depending on Submit Defines a
the type attribute. submit button
(for submitting
the form)
HTML FORM
Use <form> to create it and this element can contain other markup e.g. paragraphs,
headings
It may not contain another < form> element but could be many on a page
Every < form > element should carry at least two attributes:
action
method
May have all of the universal attributes, the UI event attributes, and the following
attributes:
enctype, accept-charset ,onsubmit ,onreset
The action Attribute
Indicates what happens to the data when the form is submitted
Its value could be a page or a method
< form action=”http://www.example.org/membership/login.aspx”
The method Attribute
Data can be sent to the server in two ways, each corresponding to an HTTP method :
The get method, which sends data as part of the URL
The post method, which hides data in something known as the HTTP headers
FORM ATTRIBUTES
The id Attribute
Uniquely identify the < form > element within a pa
The value of the id attribute should be unique within the document
id=“frmLogin”
The onsubmit Attribute
When a button is clicked or enter key then it run a script in the
browser that checks the data you entered before the form is sent to
the server
The value of the onsubmit attribute should be a script function that
would be used when this event fires.
onsubmit=”validateFormDetails();”
There are two key advantages:
If users have missed information, they do not have to wait the extra
time
The server does not have to receive as many forms with errors
Form Attributes
The onreset Attribute
Empties the form of all details, the button
might say something like clear form
If you offer a Clear Form button, however, it
is good to confirm with users that they did
intend to clear the form before performing
the action
Attribute Description
accept-charset Specifies the charset used in the
submitted form (default: the page
charset).
Action Specifies an address (url) where to
submit the form (default: the
submitting page).
autocomplete Specifies if the browser should
autocomplete the form (default:
on).
enctype Specifies the encoding of the
submitted data (default: is url-
encoded).
Method Specifies the HTTP method used
when submitting the form (default:
GET).
name Specifies a name used to identify
the form (for DOM usage:
document.forms.name).
Novalidate Specifies that the browser should
not validate the form
Single Line Text Input
<form> <input
First name:<br> type="text"> defines
<input type="text" a one-line input field
name="firstname">< for text input:
br> The form itself is not
Last name:<br> visible. Also note that
<input type="text" the default width of a
name="lastname"> text field is 20
</form> characters.
Multi-line Input
The <textarea> elem <textarea name="me
ent defines a multi- ssage" rows="10" col
line input field (a text s="30">
area): The cat was playing
in the garden.
</textarea>
Password Input
Collect sensitive data such as <form>
passwords and credit card
information. User name:<br>
<input <input type="text"
type="password"> defines name="username"><
a password field:
br>
User
password:<br>
<input type="passw
ord" name="psw">
</form>
Form Controls
14
Buttons
Used to submit a form, clear or reset and even to trigger
client - side scripts
Create a button in three ways:
Using an < input > element with a type attribute whose value is
submit , reset , or button
Using an < input > element with a type attribute whose value is
image
Using a < button > element
Attributes of button are type (submit, reset, button),
name (need iff more buttons), value (paired with name
for sending to server) and onclick (trigger an event)
Using Images for button
< input type=”image” src=”submit.jpg”
alt=”Submit” name=”btnImage” / >
It has two additional attributes src (image source) and alt (alternate
text or source)
Button
Using Button element
< button type=”submit” > Submit < /button >
< br / > < br / >
< button type=”reset” > Clear this form , I want to start again <
/button >
< br / > < br / >
< button type=”button” > < img src=”submit.gif” alt=”submit” / >
< /button >
The Button Attribute
The <button> eleme <button type="butto
nt defines a n" onclick="alert('Hel
clickable button lo World!')">Click
Me!</button>
Check Boxes &
17
Radio Button
Checkboxes and radio buttons
Little boxes on page which can be checked or unchecked by click or
spacebar key
Allow users to select several values for the same property
Helpful when
Provide a simple yes or no response with one control
Select several items from a list of possible options
< form action=”http://www.example.com/cv.aspx” method=”get”
name=”frmCV” >
Which of the following skills do you possess? Select all that apply.
< input type=”checkbox” name=”chkSkills” value=”xhtml” / > XHTML <
br / >
< input type=”checkbox” name=”chkSkills” value=”CSS” / > CSS < br / >
< input type=”checkbox” name=”chkSkills” value=”JavaScript” / >
JavaScript < br / >
< input type=”checkbox” name=”chkSkills” value=”aspnet” / > ASP.Net
< br / >
< input type=”checkbox” name=”chkSkills” value=”php” / > PHP
< /form
Check Boxes & Radio Button
Its attributes are type, name (several checkboxes may share the same
name), value (send to server) and checked (indicate selection)
Also have universal attributes, UI events and disabled , readonly , tabindex
, and accesskey
Check Box
<input <form>
type="checkbox"> d <input type="check
efines a checkbox. box" name="vehicle1
Checkboxes let a user " value="Bike"> I
select ZERO or have a bike<br>
MORE options of a <input type="check
limited number of box" name="vehicle2
choices. " value="Car"> I
have a car
</form>
Radio Buttons
20
Similar to checkboxes but there are two key differences:
When you have a group of radio buttons that share the same name,
only one of them can be selected
You should not use radio buttons for a single form control where the
control indicates on or off
Its alternative is to use a drop - down select box
Attributes are type, name, value, checked and size
Your decision between whether to use a select box or a group of
radio buttons depends on three things:
User expectations is to select one option from many.
Seeing all the options before they pick one, you should use a group of
radio buttons.
Space is not limited then use radio buttons otherwise use a drop -
down select box.
Radio Button
< form action=”http://www.example.com/flights.aspx”
name=”frmFlightBooking” method=”get” > Please select which class of
travel you wish to fly: < br / >
< input type=”radio” name=”radClass” value=”First” / > First class < br / >
< input type=”radio” name=”radClass” value=”Business” / > Business class
< br / >
< input type=”radio” name=”radClass” value=”Economy” / > Economy class
< br / >
< /form >
Radio Button Input
<input <form>
type="radio"> defin <input type="radio" n
es a radio button. ame="gender" value="
Radio buttons let a male" checked> Male<
user select ONE of a br>
limited number of <input type="radio" n
choices ame="gender" value="
female"> Female<br>
<input type="radio" n
ame="gender" value="
other"> Other
</form>
The Submit Button
<input <form action="action_p
type="submit"> defin age.php">
es a button First name:<br>
for submitting a form <input type="text" na
to a form-handler. me="firstname" value="
The form-handler is Mickey"><br>
typically a server page Last name:<br>
with a script for <input type="text" na
processing input data. me="lastname" value="
The form-handler is Mouse"><br><br>
specified in the <input type="submit"
form's action attribute: value="Submit">
</form>
The Action Attribute
The action <form action="actio
attribute defines the
n_page.php">
action to be performed
when the form is submitted.
The common way to submit
a form to a server, is by If the action attribute
using a submit button.
Normally, the form is
is omitted, the action
submitted to a web page on is set to the current
a web server. page.
In the example above, a
server-side script is
specified to handle the
submitted form:
The Method Attribute
The method <form action="action
attribute specifies _page.php" method=
the HTTP method "get">
(GET or POST) to be <form action="action
used when submitting _page.php" method=
the forms: "post">
When to Use Get & Post?
You can use GET (the You should use POST:
default method) If the form is
If the form submission is
updating data, or
passive (like a search
engine query), and includes sensitive
without sensitive information
information. (password).
When you use GET, the POST offers better
form data will be visible security because the
in the page address
GET is best suited to
submitted data is not
short amounts of data.
visible in the page
Size limitations are set in address.
your browser.
The Name Attribute
To be submitted <form action="action_
correctly, each input page.php">
field must have a First name:<br>
name attribute. <input type="text" val
This example will ue="Mickey"><br>
only submit the "Last Last name:<br>
name" input field: <input type="text" na
me="lastname" value=
"Mouse"><br><br>
<input type="submit"
value="Submit">
</form>
Select Boxes
28
A drop - down select box allows users to select on
Contained by a < select > element, while each individual option
within that list is contained within an < option > element item
from a drop - down menu
According to the XHTML specification, a < select > element
must contain at least one < option>
Its attributes are name, size (# of visible rows with scrolling)
and multiple (allow to select multiple options)
If you have a very long list of items in a select box, you can
group them together using the < optgroup > element, which
acts just like a container element for all the elements you want
within a group.
The option tag attributes are value, selected and label (replace
by element content)
The < Fieldset> attribute
Grouping Form Data <form action="action_page.p
hp">
with <fieldset> <fieldset>
The <fieldset> elem <legend>Personal
information:</legend>
ent groups related First name:<br>
data in a form. <input type="text" name="
The <legend> eleme firstname" value="Mickey"><
br>
nt defines a caption Last name:<br>
for the <fieldset> <input type="text" name="
lastname" value="Mouse"><
element. br><br>
<input type="submit" valu
e="Submit">
</fieldset>
</form>
The < Select> Element
The <select> element <select name="cars">
defines <option value="volvo"
a dropdown list: >Volvo</option>
The <option> elemen <option value="saab"
ts defines the options >Saab</option>
to select. <option value="fiat">
The list will normally Fiat</option>
show the first item as <option value="audi"
selected. >Audi</option>
You can add a selected <option value="fiat" se
attribute to define a lected>Fiat</option>
predefined option. </select>
HTML5 Input Types
HTML5 added several new input types:
color
date
datetime
datetime-local
email
month
number
range
search
tel
time
url
week
Number type Input
The <input <form>
type="number"> is Quantity (between 1
used for input fields and 5):
that should contain a <input type="numb
numeric value. er" name="quantity"
You can set min="1" max="5">
restrictions on the </form>
numbers.
Depending on
browser support, the
restrictions can apply
to the input field.
Input Restrictions
Disabled Specifies that an input field should be disabled
Max Specifies the maximum value for an input field
Maxlength Specifies the maximum number of character for an
input field
Min Specifies the minimum value for an input field
Pattern Specifies a regular expression to check the input value
against
Readonly Specifies that an input field is read only (cannot be
changed)
Required Specifies that an input field is required (must be filled
out)
Size Specifies the width (in characters) of an input field
Step Specifies the legal number intervals for an input field
Value Specifies the default value for an input field
Example
<html>
<body>
<p>
Depending on browser support:<br>
Fixed steps will apply in the input field.
</p>
<form action="action_page.php">
Quantity:
<input type="number" name="points"
min="0" max="100" step="10" value="30">
<input type="submit">
</form>
<p><b>Note:</b>type="number" is not supported in IE9 and earlier.
</p>
</body>
</html>
Date
The <input <form>
type="date"> is Birthday:
used for input fields <input type="date"
that should contain a name="bday">
date. </form>
Depending on
browser support, a
date picker can show
up in the input field.
Color
The <input <form>
type="color"> is Select your favorite
used for input fields color:
that should contain a <input type="color"
color. name="favcolor">
Depending on </form>
browser support, a
color picker can show
up in the input field.
Range
he <input <form>
type="range"> is used <input type="range
for input fields that " name="points" min
should contain a value ="0" max="10">
within a range.
</form>
Depending on browser
support, the input field
can be displayed as a
slider control.
You can use the
following attributes to
specify restrictions:
min, max, step, value.
Month
The <input <form>
type="month"> allo Birthday (month and
ws the user to select year):
a month and year. <input type="month
Depending on " name="bdaymonth"
browser support, a >
date picker can show </form>
up in the input field.
Week
The <input <form>
type="week"> allow Select a week:
s the user to select a <input type="week"
week and year. name="week_year">
Depending on </form>
browser support, a
date picker can show
up in the input field.
Time
The <input <form>
type="time"> allows Select a time:
the user to select a <input type="time"
time (no time zone). name="usr_time">
Depending on </form>
browser support, a
time picker can show
up in the input field.
datetime
The <input <form>
type="datetime"> al Birthday (date and
lows the user to time):
select a date and time <input type="dateti
(with time zone). me" name="bdaytime
The input type ">
datetime is removed </form>
from the HTML
standard. Use
datetime-local instead
Datetime local
The <input <form>
type="datetime- Birthday (date and
local"> allows the time):
user to select a date <input type="dateti
and time (no time me-
zone). local" name="bdayti
Depending on me">
browser support, a </form>
date picker can show
up in the input field.
Email
The <input <form>
type="email"> is used E-mail:
for input fields that should
contain an e-mail address.
<input type="email"
Depending on browser name="email">
support, the e-mail </form>
address can be
automatically validated
when submitted.
Some smartphones
recognize the email type,
and adds ".com" to the
keyboard to match email
input.
Search
The <input <form>
type="search"> is Search Google:
used for search fields <input type="searc
(a search field h" name="googlesear
behaves like a regular ch">
text field). </form>