Search field
A search field is used for searching and filtering items.
data:image/s3,"s3://crabby-images/d5968/d596887df9c437eee8d19763344d2f810602559a" alt="Example of two search fields. First search field in default state, label Search. Second search field with user input term, text Flights to Hawaii."
Anatomy#
data:image/s3,"s3://crabby-images/90044/90044b352477eb6ec079e9ac26623e83b5fb1fe7" alt="Image illustrating through labels the component parts of a search field, including its field, label when no search term has been input or a search term when input, and in-field button."
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/2e133/2e1334c720216e1c8a4167f1b91c23ac8c030a0a" alt="Key example showing minimum width behavior for a search field. Two search fields at their minimum widths, 3x the height of the field. First search field shows the entire label, label Search. Second search field has the user input search term Flight truncated mid-word, showing only the first four letters and an ellipsis at the end."
Minimum width#
The minimum width for a search field is 3× the height of the field, for both standard and quiet style. This minimum width guarantees that small search fields are readable and easy to target on touch devices.
data:image/s3,"s3://crabby-images/87385/87385b67afded20f6b5f593b863108b85f62df1a" alt="Key example showing the overflow behavior for search field. The user input text Flights to Hawaii is truncated after the first three letters in the word Hawaii, with an ellipsis at the end."
Text overflow#
When the entered text is too long for the available horizontal space in the field, the text truncates.
data:image/s3,"s3://crabby-images/717d7/717d79232238c464478c99d0c630f495f9d16c2e" alt="Key example of a search field with help text that has wrapped to a second line. Label, Search audiences. Help text, Search within names, descriptions, or attributes. “or attributes” is on the second line."
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/3da37/3da3713911d7712128eb6b1ae6e57219bf21e238" alt="Key example of two search fields shown in their keyboard focus states, the first showing standard style and the second in quiet style."
Keyboard focus#
A search field can be navigated using a keyboard. The keyboard focus state takes the field’s visual hover state and adds a blue ring to the field in focus.
data:image/s3,"s3://crabby-images/62650/6265077eeb4bb9b9370209d104311814bd5e9950" alt="Key example showing three text fields in different phases of a search flow. First, a default search field with no user input search term. Second, a search field in focus state and with in progress input search term Flights, with an in-field clear button. Third, a search field in the final state of a search action, showing the input term Flights to Hawaii and an in-field clear button."
In-field button#
The in-field button offers an option to clear any input search term.
If search results are being shown in a menu or popover, selecting this button will close the menu and clear the field. If a search term has been entered and the results have appeared, selecting this will only clear the field and not affect the list of results.
data:image/s3,"s3://crabby-images/7f1d1/7f1d1c932eea0bfaf4e0067cd2954e0ab41a192e" alt="Key example of two search fields in Windows high contrast black theme, one in default state and one in disabled state."
Windows high contrast mode#
In Windows high contrast mode, a search field should be displayed using the high contrast theme-specified colors for buttons. By default, the 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#
Show a "No results" state instead of an error#
Search fields do not have an error state. Search functionality should anticipate spelling mistakes in search queries, and accommodate multiple spellings of words in search results —
Instead of showing an error, show a “No results” page or a section with any suggestions for how to get results to appear.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/c5de1/c5de1c4cf85c9d38e43240cc64336fa994d23fb6" alt="Example of the correct way to show no results for a search query. A search field with user input text Flights to Hawaii shows a no results state with the explanation, No results. Adjust any search filters and try again."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/5eda5/5eda5b20b0566037f511ddaa8eb8aab69eb36556" alt="Example of the incorrect way to show no results for a search query. A search field with input user text Flights to Hawaii shows an error icon within the field."
Searching vs. filtering#
In a searching scenario, a user inputs a search term for a specific thing they’re looking for. In a filtering scenario, a user generally knows what they’re looking for, but may not have a specific thing in mind.
The search field can be used for both of these contexts. For a search experience, use the search field as-is. For a filtering experience, add a filter icon next to the search field, where a user can narrow down their search results before (or instead of) searching using a specific term. Filters can appear below the search field as tags.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/3abcc/3abcc1fc87c4942f637c3503aa192f6c6cfff6aa" alt="Examples of the correct way to design using a search field for both searching and filtering interactions. For searching, use a search field. For filtering, use a search field paired with a filter icon and tags that show filters that can be applied. Pre-set filters in this example are Flight, Hawaii, and Travel."
Searching within a category#
Create a scoped search by pairing a search field with a
Spectrum previously had a specific “search within” component that would allow a user to filter down a search field category before searching for a particular term. It was deprecated because it did not meet accessibility and localization requirements.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/cf6fb/cf6fb186da89760f09cd09240fe7b25dd63703ed" alt="Example of the correct way to design a scoped search functionality by pairing a picker with a search field. Selected picker option, Travel. Search field label, Search travel."
Include a label#
Any search field should include a label inside the field, in the default state. The default label text is Search, but this can be customized to be more specific for use cases like scoped search, wayfinding, or building context — acting like a prompt for a user to search more specifically (e.g., Search templates).
Keep in mind that once a search term is entered the label text is no longer viewable. Use help text to show search formatting examples or give hints about what to input. It can be distracting or redundant if the search field label and its help text are both communicating the same thing, so write these thoughtfully.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/f9ace/f9ace0b612162ce0b4f56f7c82d3e6fae4124522" alt="Key example showing the correct usage of including a label with a search field. Label text, Search."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/05515/055153e87a6e364d7528b82ca1998664ed7e36f3" alt="Key example showing two incorrect usages of labels in search fields. First example, a search field with no label. Second example, a search field’s label, Search, is shown in light gray italicized text, styled as placeholder text instead of label text."
Follow capitalization rules#
The label within the search field should be in sentence case, following
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/e01c5/e01c55628fbcecc4e657a2ac27583eded1170832" alt="Key example showing the correct usage of sentence case capitalization in a search field label. Only the first letter S in the label Search photos and videos is capitalized."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/c4bf0/c4bf08d2e9e5a677dca1ea289f9ac7ab01c5b219" alt="Key example showing the incorrect usage of capitalization for a search field’s label. A search field label of "Search Photos and Videos" is using title casing, where the S, P, and V are capitalized."
Internationalization#
Keyboard interactions#
Changelog#
- This component was added to the website.
- Added additional options, behaviors, usage guidelines, internationalization guidelines, keyboard interactions, and theming.
- Icon changed from UI icon to workflow icon.
- Updated colors to 6.0.0.
- Changed placeholder text to function as a label in body text style.
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.
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/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
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/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
In Spectrum for Adobe XD plugin
Component is included in the Spectrum for Adobe XD plugin.