Banner
Banner is used to highlight important information.
Page navigation navigation
Accessibility and usability expectations
Presentation
Cognition
- Bannertypes (critical, warning, success, etc.) must be communicated using more than just color to ensure understanding by all users, including those who have difficulty interpreting color signals
- Banner's are designed with visual prominence so they are emphasized and noticed by sighted users
Vision
- All text within the Bannermust have a color contrast ratio of at least 4.5:1
- Any icons used for the component must have a color contrast ratio of at least 3:1
Mobility
- If a Bannercontains links or buttons, these must meet the minimum target size of 24 by 24 CSS pixels for easier activation by users with limited dexterity
Adaptability
- The Bannermust be responsive, ensuring all content remains readable without horizontal scrolling when zoomed in up to 200% or viewed at a viewport size of 320 by 256 CSS pixels
Interaction
- When a Banneris dismissed, focus must move to a useful place on the page, preventing focus loss and allowing keyboard users to continue their journey smoothly
- When a Bannerdynamically appears on a page:- If it contains essential information, focus must move to the Banner
- If it contains non-essential information and moving focus to the banner would be disruptive, the content must be automatically announced by screen readers using a live region
 
- If it contains essential information, focus must move to the 
Keyboard
- When a Bannerdynamically appears, action controls within theBannermust be easily accessible using a keyboard
Engineering for AT Compatibility
Screen reader
- Banner's should be discoverable for screen reader users by appearing in the page’s heading hierarchy and landmarks
- A text description for the Banner’s purpose must be provided, either in theBannerheading, the accessible name of the landmark, or associated with the icon
- If a Bannercontains non-essential information, it must be automatically announced to screen readers via a live region, without moving focus
Speech recognition
- When a Bannercontains links or buttons, the visible label must match or be included in the accessible name of the control, enabling speech recognition users to operate the control effectively
Built-in accessibility features
- The Banneris rendered as a<section>landmark region, with an accessible name that indicates the type ofBanner, and contains an<h2>heading that by default indicates the type ofBanner
- The heading text can be visually hidden and over-ridden with different text
- The landmark and heading enable screen reader users to easily discover the Bannerand know what type of message it contains
- The type of Banneris conveyed by an icon, in addition to color, so that color blind users know what type of message it contains
- The icon is decorative for screen reader users and has aria-hidden="true"applied to hide it from the accessibility tree
- The Banner's icon, text content, action link and button and border color meets minimum contrast requirements for all variants
- The dismiss button has a recognizable close icon and descriptive accessible name
- The action controls and dismiss button meet the minimum target size of 24 by 24 CSS pixels
- The Banneris responsive, adjusting to the available space, with all content remaining visible and readable with no horizontal scrolling
Implementation requirements
- If a Bannercontains an action control you must provide a sufficiently descriptive label
- When using a live region, ensure that they are implemented correctly so they can be announced by all screen readers and browser combinations. See Why are my live regions not working? for further information
Feedback Banners
Banners that are used to communicate feedback require extra accessibility considerations to ensure they are immediately perceived by assistive technology users.
Consider using either a live region announcement or focus management technique:
- Live region announcements: can be used to announce the new content to screen reader users. This is the preferred method for non-critical information (though exceptions apply, such in scenarios where focus loss needs to be handled).
- Focus management: involves shifting a user's focus directly to the new Banner. This method is disruptive when used inappropriately, but is extremely helpful in scenarios where we need to guide the user towards an action.
Here are some questions to consider when deciding which method to use:
Will the user be blocked if they miss the Banner?
If a user is blocked from proceeding if they miss the Banner, moving focus is usually preferred over a live region announcement.
A prime example of this is an error banner that appears after a form validation, such as interactive error summary. Moving focus directly into the error banner allows all users (including screen reader users, zoom magnification users, and sighted keyboard users), to immediately perceive the feedback and take the necessary action to resolve the issue.
If the banner communicates non-critical information (e.g. a success banner) that wouldn't block a user if missed, a live region announcement is sufficient.
Does the Banner contain an action?
If the Banner contains an action, placing focus on the newly shown Banner may be preferred over a live region announcement, especially if the action helps unblock/guide a user within a current flow. This ensures the user can immediately interact with the action without having to manually locate it.
Where is a user's focus when the banner appears?
If a user triggers an action that results in the element that they were on being removed from the DOM (that isn't a result of a page navigation), then focus management is required. For example, let's say that a user activates a Save button successfully, and the section of the page they were on gets replaced by new content. The removal of the Save button from the DOM will result in the user's focus getting lost.
Focus loss is disorienting, especially when some assistive technology users are unexpectedly taken back to the top of the page after performing an action. This is a WCAG 2.4.3 Focus Order issue.
If the Banner appears as part of the new content on the page after a user experiences focus loss, then it may be an appropriate focus target. This does not apply to scenarios where the user is navigated to a completely new route.
Still unsure?
Many scenarios are nuanced, and can be tricky to figure out the appropriate path forward for. These benefit from additional feedback from assistive technology users.
If you're unsure about which technique is appropriate for your use case, please reach out to the Accessibility team who can help find a path forward.
How to test the component
Integration tests
- If a Bannercontains an action control it has a sufficiently descriptive label
- If a Banneris dynamically added to a page without a page reload, focus is either moved to theBanneror theBannercontent is automatically announced by screen readers through the use of a correctly implemented live region. When aBannercontains essential content focus is moved to it
Component tests
- The Bannercomponent is exposed as a section landmark with a name appropriate for its variant type
- The Bannerhas a default heading that matches the variant type
- The Bannerheading can be visually hidden and remains in the accessibility tree
- The Bannerheading text can be overridden and the landmark's name remains the default value
- The Bannericon is appropriate for the variant type
- The Bannericon hasaria-hidden="true"and is hidden from the accessibility tree
- The Banner's icon, text content, action link, and button and border color meet minimum contrast requirements, for all variants
- The dismiss button uses the close icon and has a descriptive accessible name
- The action controls and dismiss button meet the minimum target size of 24 by 24 CSS pixels
- The Banneris responsive, adjusting to the available space, with all content remaining visible and readable with no horizontal scrolling