Text field
Text fields allow users to input custom text entries with a keyboard. Various options can be shown with the field to communicate the input requirements.
data:image/s3,"s3://crabby-images/dcf19/dcf192e4101a7f7649107b9d05e3b14a773f1523" alt="Three text fields arranged vertically and labeled Email address, Password and Job title."
Anatomy#
data:image/s3,"s3://crabby-images/06e97/06e97d6d669c980bb124063f73fdefa43a71c8fb" alt="Image illustrating through labels the component parts of a text field including its field, label, required asterisk, value, character count, validation marker, and help text, description or error message."
Options#
Table of options#
From the design point of view, each component has a number of options. These options and their names are platform agnostic, and each implementation should adapt these to fit into their framework.
Behaviors#
data:image/s3,"s3://crabby-images/0af14/0af141b9bd9551ccae4185b971144113c0cfe8b2" alt="Key example displaying a standard and a quiet text field for entering the state id. "CA" for California is entered in both fields and enough padding surrounds the entered text."
Minimum width#
The minimum width for a text field is 1.5× the height of the field, for both standard style and quiet style. This minimum width guarantees that small text fields are readable and easy to target on touch devices.
data:image/s3,"s3://crabby-images/0da32/0da32254e8cd63ec4c00c5d0dd9018ff8eb8ec30" alt="Key example showing the overflow behavior for text field and text field label."
Text overflow#
When the field label is too long for the available horizontal space, it wraps to form another line. The field text itself truncates.
data:image/s3,"s3://crabby-images/6f603/6f6037382b0f9c5617ff9b33a1f2c53bd72062fd" alt="Key example showing the behavior for mixed values. The textfield value is an en dash for the label "Width"."
Mixed value#
When a text field presents multiple values that are not identical, the field should show an en dash (–).
data:image/s3,"s3://crabby-images/b5142/b51428add10de87fdc74680299a9dd4c1814d83b" alt="Key example of a text field with help text that has wrapped to a second line. Required field, label Password. Help text description, Password must be at least 8 characters."
Help text overflow#
When the help text is too long for the available horizontal space, it wraps to form another line.
data:image/s3,"s3://crabby-images/f8805/f8805d6379fa9e7031d9c82eebc8f2dcc31de1a5" alt="Key example of text fields in Windows “high contrast black” theme with label “Text field” and disabled text field with label “Disabled text field” and generic “value text” inside both fields."
Windows high contrast mode#
In Windows high contrast mode, text field should be displayed using the high contrast theme-specified colors for buttons. By default, border color should be the same as the button text color and labels should use default text color. In hover and keyboard focus states, the border color should display as the button border color. In the disabled state, border and text color should display as the disabled color.
Usage guidelines#
Include a label#
Every text field should have a label. A field without a label is ambiguous and not accessible.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/6b1d5/6b1d5799317d4e0688085673b3151f2d5ab1323f" alt="Key example showing the correct use of a label."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/2235b/2235b89a8a91dca76622f25dfafc6523c4bd5434" alt="Key example showing the incorrect use of a label. The label is missing from the text field."
Review label-less designs#
In rare cases where context is sufficient and a label could be absent, make sure to have the design reviewed and approved by an accessibility expert. These should still include an aria-label in HTML (depending on the context, “aria-label” or “aria-labelledby”).
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/c7fe7/c7fe72119bb8b0da53a1b56bea64d7f0ff9eaa9c" alt="Key example showing the correct use of a label-less text field. The text field is acting as a page counter for a pagination component, indicating page 2 followed by a text string containing the total page count "of 89 pages"."
Follow capitalization rules#
Field labels should be in sentence case.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/7cb37/7cb37474bc256bd20ced1c2ab477a1b4a937249a" alt="Key example showing the correct sentence case capitalization rule. The first letter of the label "Email address" is capitalized."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/5192a/5192abb53b262b7c2d090b2e9fa6d5f536982bbf" alt="Key example showing the incorrect sentence case capitalization rule. The first letter of each word from the label "Email Address" are capitalized."
Mark the minority of text fields in a form as required or optional#
In a single form, mark only the required fields or only the optional fields, depending on whichever is less frequent in the entire form. If most of the text fields are optional, only the required fields should be give an asterisk or have labels appended with “(required)”. If most of the text fields are required, only the optional fields should be appended with “(optional)”. An asterisk should never be used to note that a text field is optional.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/e769a/e769a68edb78784559d112da6ee6523e4222fd5f" alt="Key example showing the correct usage of limiting the required label. Two of the three text fields for the first name, last name and email address are required as the last label features the word "optional in parentheses."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/352d6/352d637149b1de51f4ca6afba1821938e4f1d1dd" alt="Key example showing the incorrect usage of marking text fields as required. Two of the three text fields feature the word "required" in parentheses while the last text field does not feature the word "required" in the label marking it as optional."
Use help text to show hints, formatting, and requirements#
The description in the help text is flexible and encompasses a range of guidance. Sometimes this guidance is about what to input, and sometime it’s about how to input. This includes information such as:
- An overall description of the input field
- Hints for what kind of information needs to be input
- Specific formatting examples or requirements
The help text’s message should not simply restate the same information in the label in order to prompt someone to interact with it. Don’t add help text if it isn’t actually relevant or meaningful to a user in order to try to maintain layout continuity with other inputs that require help text.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/d6ff6/d6ff68788d4ff8b2d11ff2785915eec2ea1d51ac" alt="Key example of correct usage of help text. Text field, label Email address. Help text, wilson@adobe.com."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/6e814/6e81482366e5e49ff836ebdc474fb97c9698cfbb" alt="Key example of incorrect usage of help text. Text field, label Email address. Help text, Enter your email address."
Don’t use placeholder text#
Putting instructions for how to complete an input, requirements, or any other essential information into placeholder text is not accessible. Once a value is entered, placeholder text is no longer viewable; if someone is using an automatic form filler, they will never get the information in the placeholder text.
Instead, use the help text description to convey requirements or to show any formatting examples that would help user comprehension. If there's placeholder text and help text at the same time, it becomes redundant and distracting, especially if they're communicating the same thing.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/3ac34/3ac34910d680852f032cc64a9c06ecda4bf3f404" alt="Key example of correct usage of help text. Text field, label Email address. Help text, wilson@adobe.com."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/f9a02/f9a02d5dcfeab9d7e9863da0b4dba2eae59c8e47" alt="Key example of incorrect usage of placeholder text instead of help text in a text field. Text field, label Email address. Placeholder text, wilson@adobe.com."
Switch help text with error text#
The help text area also displays an error message. When a text field already includes help text and an error is triggered, the help text is replaced with error text. Once the error is resolved, the help text description reappears below the field.
Since one gets replaced by the other, the language of the help text and error text need to work together to convey the same messaging. Help text explains the requirement or adds supplementary context for how to successfully complete the input. Error text tells a user how to fix the error by re-stating the input requirements or describing the necessary interaction. Make sure that the help text and the error text include the same essential information so that it isn’t lost if one replaces the other (e.g., password requirements).
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/9dc88/9dc881fc7df0d38d9564a48eec7e2b1fc05a8563" alt="Key example of correct usage of switching help text with error text. Required text field, label Password. Help text in grey color, Passwords must be at least 8 characters. Error text in red color, Create a password with at least 8 characters."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/e5a7e/e5a7e04638b7fcdca4bf6c499de0282717134d48" alt="Key example of incorrect usage of switching help text with error text. Required text field, label Password. Help text in grey color, Passwords must be at least 8 characters. Error text in red color, Passwords must be at least 8 characters."
Write error text that shows a solution#
Write error messaging in a human-centered way by guiding a user and showing them a solution — don’t simply state what’s wrong and then leave them guessing as to how to resolve it. Ambiguous error messages can be frustrating and even shame-inducing for users. Also, keep in mind that something that a system may deem an error may not actually be perceived as an error to a user.
Error text should be written in 1-2 short, complete sentences and in a clear and straightforward way. End sentences with a period, and never with an exclamation point. For text fields, the nature of the error is often related to something that needs to be fixed for in-line validation, so a
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/f85ff/f85ffdaff06539915c4ab48484a313b379743881" alt="2 key examples of correct way of writing error text. Required form field, label Credit card number, error text, Enter your credit card number. Required form field, label Password, error text, Create a password with at least 8 characters."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/d7963/d79632ef656e817c940bb814de1c65d33286073f" alt="2 key examples of correct way of writing error text. Required form field, label Credit card number, error text, Invalid field. Required form field, label Password, error text, Password requirements not met!"
Internationalization#
Keyboard interactions#
Changelog#
- Updated read-only option design
- Updated all colors to 6.0.0
- Removed placeholder text option
- Updated read-only option design
- Added type input option
- Added size option
- Added read-only option
- Updated border color to be more accessible
- Added text overflow behavior
- This component is now individually versioned (individual versions of existing components start at 5.0.0)
- Added RTL (right-to-left) guidelines
Design checklist#
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All interactive states
Includes all interactive states that are applicable (hover, down, focus, keyboard focus, disabled).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All color themes
Works properly across all four color themes (lightest, light, dark, darkest).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All platform scales
Includes a desktop scale (UWP, macOS, web desktop) and a mobile scale (iOS, Android, web mobile).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Accessible use of color
Color is not used as the only visual means of conveying information (WCAG 2.0 1.4.1).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Accessible contrast for text
Text has a contrast ratio of at least 4.5:1 for small text and at least 3:1 for large text (WCAG 2.0 1.4.3).
data:image/s3,"s3://crabby-images/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
Accessible contrast for UI components
Visual information required to identify components and states (except inactive components) has a contrast ratio of at least 3:1 (WCAG 2.1 1.4.11).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Content design
UI language and information design considerations have been incorporated into component design.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Defined options
Includes relevant options (variant, style, size, orientation, optional iconography, decorations, selection, error state, etc.)
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Defined behaviors
Includes guidelines for keyboard focus, layout (wrapping, truncation, overflow), animation, interactions, etc.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Usage guidelines
Includes a list of dos and don'ts that highlight best practices and common mistakes.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Writing guidelines
Includes content standards or usage guidelines for how to write or format in-product content for the component.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Internationalization guidelines
Works properly across various locales and includes guidelines for bi-directionality (RTL).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Keyboard interactions
Follows WCAG 2.0 standards for keyboard accessibility guidelines and includes a description of the keyboard interactions.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Design tokens
All design attributes (color, typography, layout, animation, etc.) are available as design tokens.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
UI kit
Includes a downloadable XD file that shows multiple options, states, color themes, and platform scales.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Generated UI kit
Includes a downloadable XD file, generated by code using design tokens defined in Spectrum DNA, and shows multiple options, states, color themes, and platform scales.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
In Spectrum for Adobe XD plugin
Component is included in the Spectrum for Adobe XD plugin.