search
HomeWeb Front-endJS TutorialHTML5 Forms: The Markup

HTML5 Forms: The Markup

Key Takeaways

  • HTML5 introduces a range of new input types and attributes for forms, including email, tel, url, search, number, range, date, datetime, datetime-local, month, week, time, and color, which provide native input assistance and validation without any JavaScript code.
  • HTML5 provides read-only output options, including output (the result of a calculation or user action), progress (a progress bar), and meter (a scale which can change between colors depending on the values set for the attributes). It also enables the use of label elements either around or next to the input itself with a for attribute stating the input’s ID.
  • While HTML5 input types are the future, it’s important to always use the correct input type for the data you’re requesting and validate user data on the server side. Client-side validation never has and never will be a substitute for server-side validation.
This is the first in a three-part series about HTML5 web forms. We’ll cover the basic markup in this article before progressing to styling and the client-side JavaScript validation APIs. I recommend you read this even if you’re already familiar with forms — there are many new attributes and gotchas! HTML forms may be mundane but they’re essential for the majority of web sites and apps. In HTML4, input fields were limited to:
  • input type="text"
  • input type="checkbox"
  • input type="radio"
  • input type="password"
  • input type="hidden" — for data the user cannot view
  • input type="file" — for uploads
  • textarea — for longer text entry
  • select — for drop-down lists
  • button — generally used for submitting a form, although input type="submit" and input type="image" could also be used.

Also:
  • CSS styling possibilities were limited,
  • custom controls such as date and color pickers had to be developed in code, and
  • client-side validation required JavaScript.

Additional HTML5 Input Types

A deluge of new input types have been introduced. These provide native input assistance and validation without any JavaScript code…
type description email enter an email address tel enter a telephone number — no strict syntax is enforced but line breaks will be removed url enter a URL search a search field with line breaks automatically removed number a floating point number range a control for entering an approximate value, typically represented by a slider date enter the day, month and year datetime enter the day, month, year, hour, minute, second and microsecond based on the current UTC timezone datetime-local enter a date and time with no timezone month enter the month and year with no timezone week enter a week number with no timezone time enter the time with no timezone color specify a color

Input Attributes

Unless stated otherwise, input fields can have any of the following form-specific attributes. Several are Boolean attributes, that is, they do not require values, e.g
<span><span><span><input> type<span>="email"</span> name<span>="email"</span> required /></span></span></span>

although you can add them if you prefer a stricter XHTML-like syntax, e.g.
<span><span><span><input> type<span>="email"</span> name<span>="email"</span> required<span>="required"</span> /></span></span></span>

attribute description name the input field name value an initial value checked checks a checkbox or radio input maxlength the maximum length of the entered string. This can also be applied to textarea fields in HTML5 minlength the minimum length of the entered string. This is documented but, at the time of writing, browser support is poor and the attribute causes HTML validators to error. An alternative option is pattern=".{3,}" which would enforce at least three characters. placeholder a subtle text hint shown in the input box autofocus set focus to this (non-hidden) field when the page loads required indicates that a value must be entered pattern ensures a value adheres to a regular expression min the minimum value permitted (numeric and date types) max the maximum value permitted (numeric and date types) step the value granularity. For example, input type="number" min="10" max="19" step="2" would only permit the values 10, 12, 14, 16 or 18. autocomplete provides the browser with a hint for auto-completion, e.g. “billing email” or can be set to “on” or “off” to enable and disable accordingly inputmode specifies the input mechanism. The most useful options:
  • verbatim — non-prose content such as usernames
  • latin — latin script such as search fields
  • latin-name — names, i.e. with initial letter capitalization
  • latin-prose — prose content such as messages, tweets, etc.
  • numeric — numeric input where number or range would not be appropriate, e.g. credit card numbers
size the size in characters for text or password inputs or pixels for email, tel, url or search inputs. Probably best avoided since you should use CSS to style fields. rows number of text rows (textarea only) cols number of text columns (textarea only) list points to a set datalist options spellcheck set to true or false to enable or disable spell checking form the ID of the form which this input belongs to. In general, inputs should be nested inside a form, but this attribute permits an input to be defined anywhere on the page formaction specifies a URI to override the form action when submitting (submit buttons/images only) formmethod specifies GET or POST to override the form method when submitting (submit buttons/images only) formenctype specifies the type of content when submitting (text/plain, multipart/form-data or application/x-www-form-urlencoded on submit buttons/images only) formtarget specifies a target window/frame to override the form target when submitting (submit buttons/images only) readonly the input value cannot be changed although it will be validated and submitted disabled disables the input — no validation will occur and data will not be submitted
Note that date fields must always use YYYY-MM-DD for value, min and max attributes.
The following example requests a mandatory email which ends in @mysite.com and has focus when the page loads:
<span><span><span><input> type<span>="email"</span> name<span>="email"</span> required /></span></span></span>

Datalists

A datalist contains a set of suitable options for any type of input, e.g.
<span><span><span><input> type<span>="email"</span> name<span>="email"</span> required<span>="required"</span> /></span></span></span>

When datalist is supported, the browser presents auto-complete options when you start to type. The whole list is usually shown if you double-click the control or click the down arrow (if shown). Unlike a standard select drop-down, the user is free to override these choices and enter their own value. It’s possible to set values and text like standard select options, e.g.
<span><span><span><input>
</span></span><span>  <span>type<span>="email"</span>
</span></span><span>  <span>name<span>="login"</span>
</span></span><span>  <span>pattern<span>="@mysite\.com$"</span>
</span></span><span>  <span>autocomplete<span>="email"</span>
</span></span><span>  <span>autofocus
</span></span><span>  <span>required /></span></span></span>

but be aware that implementations differ. For example, Firefox auto-completes on the text itself (Internet Explorer) while Chrome prefers the value (IE) and shows the text greyed out:
HTML5 Forms: The Markup
Datalists can be populated by JavaScript if you wanted to retrieve options via Ajax.

Disabling Validation

Validation for the whole form can be disabled by setting a novalidate attribute on the form element. Alternatively, you can set a formnovalidate attribute on the form’s submit button/image. Remember also that setting an input’s disabled attribute will prevent validation on that field.

Output Fields

While we’re primarily discussing input types, HTML5 also provides read-only output options:
  • output — the result of a calculation or user action
  • progress — a progress bar (the value and max attributes define the status)
  • meter — a scale which can change between green, amber and red depending on the values set for the attributes value, min, max, low, high and optimum

Separating and Labeling Inputs

The whatwg.org form specification states:
Each part of a form is considered a paragraph, and is typically separated from other parts using

elements

Interesting. I normally use a div although I doubt it matters from a semantic perspective. A p tag is shorter although it’s possible you’ll need to apply a class to modify margins. More importantly, you should use label elements either around or next to the input itself with a for attribute stating the input’s ID, e.g.
<span><span><span><input> type<span>="email"</span> name<span>="email"</span> required /></span></span></span>

No Standard Controls

There are no specific interface guidelines for browser vendors to follow. This is intentional: a typical desktop mouse-controlled date picker can be too small on a mobile device so the vendor can implement a touch-based alternative.

Browser Support

Not every input type and attribute is supported in all browsers. In general, most modern browsers from IE10 include basics such as email and number. However, the date types are only supported in Webkit and Blink browsers at the time of writing. The browser will revert to a standard text input when a specific type and ignore attributes when those values are not supported.

Always Use the Correct Type!

It’s important to use the correct input type for the data you’re requesting. That may seem obvious but you will encounter situations when you’ll be tempted to use a standard text input. Consider dates. Support is patchy and this leads to implementation issues:
  1. The standard date input always returns dates in YYYY-MM-DD format regardless of how the date picker is presented in your locale.

  2. IE and Firefox will fall back to a standard text input, but your users may expect to enter values in US MM-DD-YYYY or European DD-MM-YYYY format.

  3. A JavaScript date picker such as the one in jQuery UI allows you to define a custom format — or even YYYY-MM-DD for consistency — but you cannot guarantee JavaScript will be enabled.
The easy solution is to abandon the HTML5 date input, revert to text and implement your own date control. Don’t. You will never create a custom date picker which works in all devices at all screen resolutions, supports keyboard, mouse and touch input and continues to operate when JavaScript is disabled. In particular, mobile browsers are often ahead of their desktop cousins and implement good touch-screen controls. The HTML5 input types are the future. Use them and, if necessary, add JavaScript polyfills in situations where you require good cross-browser support. But remember to…

Validate Server-Side

Browser validation is not guaranteed. Even if you forced everyone to access using the latest version of Chrome you could never prevent:
  • browser bugs or JavaScript failures permitting invalid data
  • the user changing your HTML or scripts using browser tools
  • submission from systems outside your control, or
  • data interception between the browser and the server (certainly over HTTP).
Client-side validation never has and never will be a substitute for server-side validation. Validating user data on the server is essential. On the client, it’s a nice-to-have. Finally, remember dates may be received in YYYY-MM-DD or whichever format you specified to the user (MM-DD-YYYY, DD-MM-YYYY, etc.) Check for digits in the first four characters or use native language/framework date parsing methods as necessary. We’ve covered a lot in this article. In the next part we’ll look at form-related CSS properties.

Frequently Asked Questions (FAQs) about HTML5 Forms Markup

What is the importance of using HTML5 in form markup?

HTML5 introduces a range of new input types and attributes that provide a better user experience for form filling. These new features allow for more specific input types, such as email, date, and time, which can be validated by the browser itself, reducing the need for additional JavaScript. This leads to cleaner, more efficient code and a smoother user experience.

How does HTML5 improve accessibility in form markup?

HTML5 provides several features that enhance accessibility. For instance, the “required” attribute can be used to ensure that essential fields are filled in. The “placeholder” attribute can provide hints to users about what type of information is expected in a field. Additionally, the “autofocus” attribute can automatically focus the cursor on a particular input field when the page loads, guiding the user’s interaction with the form.

What are some common mistakes to avoid when using HTML5 for form markup?

One common mistake is not properly using the new input types and attributes introduced in HTML5. For example, using the wrong input type can lead to incorrect data being submitted. Another mistake is not providing adequate fallbacks for older browsers that do not support HTML5. This can lead to a poor user experience for those using older technology.

How can I use HTML5 to create more interactive forms?

HTML5 introduces several new form elements that can be used to create more interactive forms. For example, the “datalist” element can be used to create a dropdown list of options for an input field, while the “progress” and “meter” elements can be used to visually represent the progress of a task or the current value within a known range, respectively.

How does HTML5 handle form validation?

HTML5 introduces built-in form validation through the use of certain attributes. For example, the “required” attribute can be used to ensure that a field is not left empty, while the “pattern” attribute can be used to specify a regular expression that the input field’s value must match. If the input does not meet these criteria, the form will not be submitted and the user will be prompted to correct their input.

What are the benefits of using semantic elements in HTML5?

Semantic elements in HTML5 provide a clear indication of what type of content is contained within them, making it easier for both developers and machines (like search engines) to understand the structure and content of a webpage. This can improve search engine optimization and accessibility.

How can I ensure my HTML5 forms are compatible with older browsers?

While HTML5 is widely supported by modern browsers, it’s important to provide fallbacks for older browsers that may not support all HTML5 features. This can be done by using JavaScript to detect whether a browser supports a particular feature and providing an alternative implementation if it does not.

How can I use HTML5 to improve the mobile experience of my forms?

HTML5 introduces several features that can improve the mobile experience of forms. For example, the “autofocus” attribute can be used to automatically focus the cursor on a particular input field when the page loads, reducing the need for users to manually tap the field. Additionally, the new input types like “email” and “tel” bring up specialized keyboards on mobile devices, making it easier for users to input the correct type of data.

What are some best practices for structuring a web form in HTML5?

Some best practices for structuring a web form in HTML5 include grouping related form controls using the “fieldset” element, providing descriptive labels for all form controls using the “label” element, and using the “legend” element to provide a caption for each “fieldset”. Additionally, it’s important to use the appropriate input types and attributes to ensure data validity and improve user experience.

How can I use CSS to style my HTML5 forms?

CSS can be used to style HTML5 forms in a variety of ways. For example, you can use CSS to change the color, size, and font of form elements, add borders and backgrounds, and apply hover effects. Additionally, CSS can be used to control the layout of form elements, such as aligning form controls and labels, and creating multi-column forms.

The above is the detailed content of HTML5 Forms: The Markup. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Replace String Characters in JavaScriptReplace String Characters in JavaScriptMar 11, 2025 am 12:07 AM

Detailed explanation of JavaScript string replacement method and FAQ This article will explore two ways to replace string characters in JavaScript: internal JavaScript code and internal HTML for web pages. Replace string inside JavaScript code The most direct way is to use the replace() method: str = str.replace("find","replace"); This method replaces only the first match. To replace all matches, use a regular expression and add the global flag g: str = str.replace(/fi

Custom Google Search API Setup TutorialCustom Google Search API Setup TutorialMar 04, 2025 am 01:06 AM

This tutorial shows you how to integrate a custom Google Search API into your blog or website, offering a more refined search experience than standard WordPress theme search functions. It's surprisingly easy! You'll be able to restrict searches to y

8 Stunning jQuery Page Layout Plugins8 Stunning jQuery Page Layout PluginsMar 06, 2025 am 12:48 AM

Leverage jQuery for Effortless Web Page Layouts: 8 Essential Plugins jQuery simplifies web page layout significantly. This article highlights eight powerful jQuery plugins that streamline the process, particularly useful for manual website creation

Build Your Own AJAX Web ApplicationsBuild Your Own AJAX Web ApplicationsMar 09, 2025 am 12:11 AM

So here you are, ready to learn all about this thing called AJAX. But, what exactly is it? The term AJAX refers to a loose grouping of technologies that are used to create dynamic, interactive web content. The term AJAX, originally coined by Jesse J

What is 'this' in JavaScript?What is 'this' in JavaScript?Mar 04, 2025 am 01:15 AM

Core points This in JavaScript usually refers to an object that "owns" the method, but it depends on how the function is called. When there is no current object, this refers to the global object. In a web browser, it is represented by window. When calling a function, this maintains the global object; but when calling an object constructor or any of its methods, this refers to an instance of the object. You can change the context of this using methods such as call(), apply(), and bind(). These methods call the function using the given this value and parameters. JavaScript is an excellent programming language. A few years ago, this sentence was

10 Mobile Cheat Sheets for Mobile Development10 Mobile Cheat Sheets for Mobile DevelopmentMar 05, 2025 am 12:43 AM

This post compiles helpful cheat sheets, reference guides, quick recipes, and code snippets for Android, Blackberry, and iPhone app development. No developer should be without them! Touch Gesture Reference Guide (PDF) A valuable resource for desig

Improve Your jQuery Knowledge with the Source ViewerImprove Your jQuery Knowledge with the Source ViewerMar 05, 2025 am 12:54 AM

jQuery is a great JavaScript framework. However, as with any library, sometimes it’s necessary to get under the hood to discover what’s going on. Perhaps it’s because you’re tracing a bug or are just curious about how jQuery achieves a particular UI

How do I create and publish my own JavaScript libraries?How do I create and publish my own JavaScript libraries?Mar 18, 2025 pm 03:12 PM

Article discusses creating, publishing, and maintaining JavaScript libraries, focusing on planning, development, testing, documentation, and promotion strategies.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor