Skip to content

Navigation links need better styling #31

Open
@mxmason

Description

Summary

Several states of our navigation links need visual improvement:

  1. the default state
  2. the hover state
  3. the current page state

Default state

A link should provide some kind of obvious visual clue to tell the user that it's a link. Right now, our navigation links look like plain text.

The user has to infer from context clues that these are links. They shouldn't have to do this.

Hover state

Right now, our navigation links stay the same when a user hovers on them. Some other design change, like a text underline, will make it clearer to the user that they’re interacting with a link.

Current page state

When users are interacting with a site navigation, they need some kind of indicator (or affordance) about which page they're on in that navigation. Right now, our Navigation component provides some affordance to assistive technology users through the use of aria-current, but there is no visual affordance for sighted users who are not using assistive technology.

We could style the current navigation element with some combination of color and shape to show the user that they're on that page.

Notes and inspiration from around the web

It's important that styles for our hover and current page states provide clear meaning both separately and together

In this screenshot from the UK Government Design System website, the "Components" page is the current page, and the user has hovered over the "Patterns" link. There is a blue bar beneath the area of the "Components" link to indicate that it is the current page, and the text of the "Patterns" link has been underlined and darkened to indicate that the user is hovering on it.

CleanShot 2022-12-23 at 14 33 27@2x

In this screenshot, "Components" is the current page and the user is also hovering over "Components". Notice how the visual cues for both hover and navigation remain visible, and do not interfere with each other.

CleanShot 2022-12-23 at 14 30 33@2x

💡 Note: The goal isn't necessarily to make out website look like this; it's to think about how we can create some styles that fill both of the gaps listed in this issue!

Relevant links

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions