Forms

Example

HTML code


Jinja2 template code for Wagtail CMS


This page covers use cases, specs, accessibility, and responsive considerations for major form field UI components.

In general, forms should be as simple and direct as possible to minimize scrolling (think mobile first). Keep your questions to a minimum and only ask what is absolutely needed. Make inputs as self-explanatory as possible, with a minimum of helper text.

Avoid the use of disabled fields where possible, and instead hide disabled fields until they become relevant and can be enabled.

Source Code

General principles

Usability

Choose the appropriate width for text input fields so they match the kind of information requested. This makes it easier for users to quickly grasp what’s being asked.

For example, it’s hard to understand at a glance that a single 1,000 px-wide text field is asking for your phone number or birth date. When possible, be even more explicit with the width by dividing it into known character counts. For instance, social security number should be three characters, then two, then four. Be mindful of not getting too restrictive, however. This approach could work for phone numbers, but only if international numbers are not permitted.

These types of inputs should always be smaller widths:

  • Middle initial
  • Date, month, or year
  • State abbreviation

Responsive design

As the screen size gets smaller, break multi-column inputs into a single, stacked column. Fields that are next to each other on a large screen, should stack at smaller screen sizes. When possible, fields should span the entire width of the screen at the smallest screen sizes.

Accessibility

Users of screen readers use the tab key to move focus from one form control to another. Make sure that tab focus order reflects the way you would like users to navigate through the form. Consider whether tabs should move a user down or across the page.


Text input fields

States

Default

  • Border: 1 px, Gray 60 (#919395)
  • Height: 35 px
  • Padding: 7px
  • Avenir Next Regular, 16px, Gray (#5a5d61)
  • Text should be in sentence case

Hover

  • Border: 2 px, Pacific (#0072ce)

Focus

  • Border: 2 px, Pacific (#0072ce)
  • Outline: Dotted 1px, Pacific (#0072ce)
  • Outline offset: 1px

Disabled

  • Background: Gray 10 (#e7e8e9)

Multi-line

Use for long-form answers.

  • Border: 1 px, Gray 60 (#919395)
  • Avenir Next Regular, 16 px, Gray (#5a5d61)


Labels and helper text

Labels

Basic label

  • Avenir Next Medium, 18 px, Black (#101820)
  • Positioned above the input field, left aligned
  • Margin bottom: 10 px

Inline label

  • Avenir Next Regular, 16 px, Black (#101820)
  • Positioned to the right of the input field, inline


Helper text

For screen reader accessibility, consider using the aria-describedby attribute for helper text, which gives screen readers users the information if they need while allowing more flexibility with placement.


Placeholder text

Use placeholder text for formatting examples only. Don’t use for instructions. Placeholder text disappears once a user begins typing in the field.

  • Avenir Next Regular, 16 px, Gray (#5a5d61)


Block helper text

Use block helper text to explain why a piece of information is being requested, address security and privacy concerns, or to suggest ways of providing answers other than providing formatting examples.

  • Avenir Next Regular, 16 px, Gray (#5a5d61)
  • Margin top: 10 px
  • Margin bottom: 10 px

Inline helper text

Use to indicate whether a field is optional or required.

  • Avenir Next Regular, 16 px, Gray (#5a5d61)
  • Margin bottom: 10 px
  • Helper text should be lowercase and placed in parenthesis after the label

Required vs. optional fields

Where possible, design your forms to only include required fields. If it’s not required, ask yourself if it’s really necessary to include at all. Add instructions at the top of the form to clearly indicate that all fields are required unless otherwise noted. If a field is optional, indicate it with inline helper text, as shown here. Don’t indicate which fields are required; that would only introduce redundant visual noise.

Try not to design forms consisting mainly of optional fields. If you must do so, mark required field labels only with inline helper text.



Fieldset

The fieldset element is used to group several controls as well as labels within a web form.

The fieldset includes:

  • Legend
  • Block helper text (if necessary)
  • Inline labels
  • Set of controls
Legend Use block helper text for instructions.

Legend

The legend serves as the heading for the fieldset

  • Avenir Next Medium, 18 px, Black (#101820)
  • Positioned above a group of input fields, left aligned

Inline label

  • Avenir Next Regular, 16 px, Black (#101820)
  • Positioned to the right of the input field, inline

Set of controls

  • Checkboxes
  • Radio buttons
  • Input fields


Notifications

Where possible, display formatting errors immediately using client-side validation so the user doesn’t have to wait until submitting to see what went wrong (this is especially frustrating if the information the user enters the first time around is not cached on submit and they have to fill out all the fields again from scratch). If letters are entered in a date field, if an email address is missing the “@” sign, let the user know right away by showing a field-level error on blur.

That said, it’s a good idea to always validate on the server side even if you use client-side validation for formatting checks. That’s because JavaScript validation may not work on all clients; JavaScript errors could occur no matter the client; and JS validation can easily be bypassed, which raises security concerns.

In general, the best practice for server-side validation is to mark errors with both form-level and field-level errors.

Accessibility

For screen reader accessibility, form-level errors should include anchor links to the problem field in question. In general, use distinct icons, contrasting colors, prominent placement, and text to indicate errors. Don’t rely on just one method, as users can have many different accessibility needs (color blind users, visually impaired users, users with motor control issues, etc.).

States

Action

The action notification displays when something is happening on the page, such as a page loading notification as search results are found. Use animated minicons to reassure the user that an action is functioning as intended.

  • Border: 1 px, Gray 40 (#b4b5b6)
  • Background: Gray 10 (#f7f8f9)
  • Padding: 15px
  • H4 (Avenir Next Medium, 18 px) Black (#101820)
  • Minicon: 18 px, Gray (#5a5d61)
The page is loading…

Success

The success notification displays when an operation has run as expected, such as returning the number of results in a search or a form has been successfully submitted.

  • Border: 2 px, CFPB Green (#20aa3f)
  • Background: Green 20 (#e2efd8)
  • Minicon: 18px, CFPB Green (#20aa3f)
11 results

Success (field-level)

  • Border: 2 px, CFPB Green (#20aa3f)
  • Minicon: 18 px, CFPB Green (#20aa3f)
  • Success minicon and message should always appear below input field

Warning

The warning notification displays when an operation has run as expected, but doesn’t have the expected results,such as a search that returned no results.This can also be used to display additional critical information to a user before they submit a form, such as how their data will be used and protected or a reminder that they can’t edit their responses after submitting.

  • Border: 2 px, Gold (#ff9e1b)
  • Background: Gold 20 (#fff0dd)
  • Minicon: 18px, Gold (#ff9e1b)
No results found

Warning (field-level)

  • Border: 2 px, Gold (#ff9e1b)
  • Minicon: 18 px, Gold (#ff9e1b)
  • Warning minicon and message should always appear below input field

Error

The error notification displays when an operation has not run as expected and encounters an error. Use after validating on the server side to call out input errors preventing form submission.

  • For screen reader accessibility, include anchor links to the fields that need correction
  • Place form-level alerts below the form title
  • Border: 2 px, Red (#d14124)
  • Background: Red 20 (#fff0dd)
  • Minicon: 18px, Red (#d14124)
Page not found

Error (field-level)

  • Border: 2 px, Red (#d14124)
  • Minicon: 18 px, Red (#d14124)
  • Error minicon and message should always appear below input field


Checkboxes

Use checkboxes when the user can select more than one option from a list. Make clear with helper text that this is the case.

Usability

To optimize usability, consider using checkboxes with large target areas. If these won’t fit into the design and the default style shown below is used, make sure the target area is at least 45 x 45px and that it includes the text label.

Selecting the checkbox or touching the label text next to it should toggle the state of the checkbox on and off.

Accessibility

To optimize screen reader accessibility, lay out checkboxes vertically rather than horizontally.

States

Default

  • Height: 20 px
  • Width: 20 px
  • Margin right: 10 px
  • Border: 1 px, Gray 60 (#919395)
  • Background: White (#ffffff)
  • Avenir Next Regular, 16 px, Black (#101820)

Hover

  • Border: 2 px, Pacific (#0072ce)

Focus

  • Border: 2 px, Pacific (#0072ce)
  • Outline: Dotted 1px, Pacific (#0072ce)
  • Outline offset: 1px

Selected

  • Border: 1 px, Gray 60 (#919395)
  • Minicon: 18 px, Black (#101820)

Disabled

  • Border: 1 px, Gray 60 (#919395)
  • Background: Gray 10 (#e7e8e9)
  • Avenir Next Regular, 16 px, Gray (#5a5d61)


Nested checkboxes

There are times when checkboxes may be nested with parent/child relationships. This is common when used within filter interactions.

Usability

In this case, the following behavior and design should be followed:

  • Parent is “collapsed” and displays an expandable arrow at the end of the text
  • The label of the parent checkbox should be clickable
  • Clicking on the label or arrow toggles the opening/closing of the child options
  • In open state, arrow points up; in closed state, arrow points down
  • Child options are in black text and not clickable
  • Clicking on the parent checkbox selects the parent option and all child options
  • Clicking on the parent checkbox does not change the state of the open/close expansion (if it’s checked with the children expanded, it stays expanded, for instance)

States

Indeterminate

  • Border: 2px, Dark Gray (#43484e)
  • Background: 12 x 12px square centered, Gray 80 (#75787b)

Nested checkboxes (closed)

  • Label: Pacific (#0072ce)
  • Arrow pointed down

Nested checkboxes (open)

  • Label: Pacific (#0072ce)
  • Arrow pointed up
  • Child checkbox options left aligned with parent label


Radio buttons

Use radio buttons when the user can choose only one option out of a list. Use these for a small number of discrete elements—avoid long lists of radio buttons (usually no more than 6-8 options).When there are more than two options, stack radio buttons vertically.

Usability

Leave radio buttons unselected as the default. It’s easy for users to miss that a radio button has been preselected and to submit a form with an erroneous answer.

Never use radio buttons for optional questions. Once a radio button is selected from a list, it or another choice must remain selected and there is no undoing the selection unless you reload the form.

Consider using radio buttons with large target areas. If these won’t fit into your design and you need to use the default style shown below, make sure the target area is at least 45 x 45 px and includes the option text.

Accessibility

There are some issues with voiceover reading radio buttons. To get around this, consider using the aria-describedby attribute.

States

Default

  • Height: 20 px
  • Width: 20 px
  • Border: 1 px, Gray 60 (#919395)
  • Background: White (#ffffff)
  • Margin right: 10 px
  • Avenir Next Regular, 16 px, Black (#101820)

Hover

  • Border: 2 px, Pacific (#0072ce)

Focus

  • Border: 2 px, Pacific (#0072ce)
  • Outline: Dotted 1px, Pacific (#0072ce)
  • Outline offset: 1px

Selected

  • Border: 1 px, Gray 60 (#919395)
  • Background: 14 px x 14 px, Pacific (#0072ce)

Disabled

  • Border: 1 px, Gray 60 (#919395)
  • Background: Gray 10 (#e7e8e9)
  • Avenir Next Regular, 16 px, Gray (#5a5d61)


Checkboxes and radio buttons with large target areas

For better usability, consider using checkboxes and radio buttons with large target areas. These are easier to interact with (especially on smaller screens) and harder to miss. They are especially desirable when the form will have heavy mobile usage. Given the amount of real estate they occupy, they’re probably not suited for all use cases; for example, they may not work well for terms of service agreement checkboxes.

States

Default

Target area

  • Minimum height: 50px
  • Background: Gray 10 (#e7e8e9)
  • Padding: 15 px

Radio button (or checkbox) and text

  • Border: 1 px, Gray 60 (#919395)
  • Background: 20 px x 20 px, White (#ffffff)
  • Avenir Next Regular, 16 px, Black (#101820)

Hover

Target area

  • Border: 2 px, Pacific (#0072ce)
  • Background: Gray 10 (#e7e8e9)

Radio button (or checkbox)

  • Border: 2 px, Pacific (#0072ce)

Focus

Target area

  • Border: 2 px, Pacific (#0072ce)
  • Background: Gray 10 (#e7e8e9)
  • Outline: Dotted 1px, Pacific (#0072ce)

Radio button (or checkbox)

  • Border: 2 px, Pacific (#0072ce)

Selected

Target area

  • Border: 1 px, Pacific (#0072ce)
  • Background: Pacific 20 (#d6e8fa)

Radio button (or checkbox)

  • Border: 1 px, Pacific (#0072ce)
  • Background: 14 x 14 px, Pacific (#0072ce)

Disabled

Radio button (or checkbox)

  • Border: 1 px, Gray 60 (#919395)
  • Background: Gray 20 (#d2d3d5)
  • Avenir Next Regular, 16 px, Gray (#5a5d61)


While dropdowns are easy to implement, they aren’t always the best choice from a usability perspective.

Use dropdowns when:

  • You have a long list of finite options. If the list is shorter than around six items, radio buttons might work better. If the options include something open ended, a text input field is better.

  • You need structured data for a long list. For instance, an open text field for “state” could be entered as Missouri or MO. So if this needs to be standardized, a dropdown facilitates this standardization.

  • The list options are familiar to the user. A dropdown is not a good place to introduce new or complicated terms or concepts. For instance, if the question is “What’s your favorite color of the rainbow,” a dropdown could be a good choice. The options are familiar and there are more than six. You don’t want the user to have to read and absorb a lot of new information in a dropdown.

Also keep in mind that dropdowns behave differently on various mobile devices, taking up different amounts of real estate and requiring different interactions. Mobile also doesn’t allow for the use of typeahead to navigate quickly to an item in a list, so navigating long lists can be especially cumbersome.

Accessibility

From an accessibility standpoint, browser defaults for multiple select components require the use of a mouse (e.g. holding down the control key and clicking several items). The default components are a poor choice for the visually impaired. If a multi-select component is desired, use custom JavaScript to make it accessible.

States

Default

  • Height: 35 px
  • Padding: 7 px
  • Border: 1 px, Gray 60 (#919395)
  • Background (down caret box): Gray 10 (#e7e8e9)
  • Minicon: Gray 80 (#75787b)
  • Body (Avenir Next Regular, 16px), Black (#101820)

Hover

  • Border: 2 px, Pacific (#0072ce)

Focus

  • Border: 2 px, Pacific (#0072ce)
  • Outline: Dotted 1px, Pacific (#0072ce)

Disabled

  • Background: Gray 10 (#e7e8e9)
  • Avenir Next Regular, 16 px, Gray (#5a5d61)


Range sliders

Range sliders can work well for discovery and education, where the inputs are a relative quantity and not a specific numeric input. As an example, users can narrow a list of flight options on kayak.com with sliders that show a range of takeoff times. Sliders are an elegant and intuitive way to allow the user to discover which takeoff times will yield the lowest fares.

Because they’re imprecise and difficult to manipulate, range sliders are not a good choice when the user is likely to have a specific number that they want to input. If you choose to implement a slider in this latter case, consider adding steppers or an input box as an alternative means of entering the same data. Also consider the balance between the length of the slider and the number of data points it covers (the range as well as how discrete the points are). The more points to choose from, the harder it is for the user to target a specific number.

Accessibility

Make sure that sliders are accessible by keyboard using the arrow keys.

States

Default

Track

  • Height: 9 px
  • Border: 1 px, Gray 40 (#b4b5b6)
  • Background: Gray 80 (#75787b)

Handle

  • Border: 1 px, Gray 40 (#b4b5b6)
  • Background: 45 px x 45 px, Gray 10 (#e7e8e9)

Focus

  • Border: 2 px, Pacific (#0072ce)
  • Background: Pacific 20 (#d6e8fa)