An open API service indexing awesome lists of open source software.

https://github.com/accessible-ui/link

🅰 A component that adds aria attributes and keydown events to non-A elements in order to make them act like native links
https://github.com/accessible-ui/link

a11y a11y-link accessibility accessible accessible-link accessible-react aria-link react-accessibility

Last synced: 2 months ago
JSON representation

🅰 A component that adds aria attributes and keydown events to non-A elements in order to make them act like native links

Awesome Lists containing this project

README

        





<AccessibleLink>




Bundlephobia


Types


Code coverage


Build status


NPM Version


MIT License

npm i @accessible/link


A component that adds aria attributes and keydown events to non-A elements in order to make them act like native links.

## Quick Start

[Check out the example on CodeSandbox](https://codesandbox.io/s/accessiblelink-examples-rohqw)

```jsx harmony
import {Link as AccessibleLink} from '@accessible/link'

const LinkButton = () => (

(window.location.href = '/foo')}>Go to /foo

)
```

## API

### <Link>

Adds `role="link"` and `tabIndex={0}` props to its child component unless those props are already
defined in the child component's props. Also adds a `keydown` event for the `Enter` key which
causes the component's `onClick` property to fire.

#### Props

| Prop | Type | Default | Required? | Description |
| -------- | -------------------- | ----------- | --------- | --------------------------------------------------------------------- |
| children | `React.ReactElement` | `undefined` | Yes | The component you want to add accessible roles and keydown events to. |

### useA11yLink(target, onClick)

A React hook for adding a11y properties and link/role=link interop to elements.

```jsx harmony
const Link = () => {
const ref = React.useRef(null)
const a11yProps = useA11yButton(ref, (event) => {
// This is your `onClick` handler
navigate.to('/home')
event.preventDefault()
})
return
}
```

#### Arguments

| Argument | Type | Required? | Description |
| -------- | ---------------------------------------------------------- | --------- | ---------------------------------------------------------------------------------------------------- |
| target | React.RefObject<T> | T | null | Yes | A React ref or HTML element | |
| children | `React.ReactElement` | Yes | The component you want to turn into a button that handles focus and `space`, `enter` keydown events. |

#### Returns

```ts
{
readonly onClick: (event: React.MouseEvent) => void;
readonly role: "button";
readonly tabIndex: 0;
}
```

## LICENSE

MIT