Skip to content

octatone/eslint-plugin-jsx-a11y

 
 

Repository files navigation

build status npm version license Coverage Status Total npm downloads

eslint-plugin-jsx-a11y

Static AST checker for accessibility rules on JSX elements.

Why?

Ryan Florence built out this awesome runtime-analysis tool called react-a11y. It is super useful. However, since you're probably already using linting in your project, this plugin comes for free and closer to the actual development process. Pairing this plugin with an editor lint plugin, you can bake accessibility standards into your application in real-time.

Note: This project does not replace react-a11y, but can and should be used in conjunction with it. Static analysis tools cannot determine values of variables that are being placed in props before runtime, so linting will not fail if that value is undefined and/or does not pass the lint rule.

Installation

You'll first need to install ESLint:

$ npm i eslint --save-dev

Next, install eslint-plugin-jsx-a11y:

$ npm install eslint-plugin-jsx-a11y --save-dev

Note: If you installed ESLint globally (using the -g flag) then you must also install eslint-plugin-jsx-a11y globally.

Usage

Add jsx-a11y to the plugins section of your .eslintrc configuration file. You can omit the eslint-plugin- prefix:

{
  "plugins": [
    "jsx-a11y"
  ]
}

Then configure the rules you want to use under the rules section.

{
  "rules": {
    "jsx-a11y/rule-name": 2
  }
}

Supported Rules

  • aria-props: Enforce all aria-* props are valid.
  • aria-proptypes: Enforce ARIA state and property values are valid.
  • aria-role: Enforce that elements with ARIA roles must use a valid, non-abstract ARIA role.
  • aria-unsupported-elements: Enforce that elements that do not support ARIA roles, states, and properties do not have those attributes.
  • heading-has-content: Enforce heading (h1, h2, etc) elements contain accessible content.
  • href-no-hash: Enforce an anchor element's href prop value is not just #.
  • html-has-lang: Enforce <html> element has lang prop.
  • img-has-alt: Enforce that <img> JSX elements use the alt prop.
  • img-redundant-alt: Enforce <img> alt prop does not contain the word "image", "picture", or "photo".
  • label-has-for: Enforce that <label> elements have the htmlFor prop.
  • lang: Enforce lang attribute has a valid value.
  • mouse-events-have-key-events: Enforce that onMouseOver/onMouseOut are accompanied by onFocus/onBlur for keyboard-only users.
  • no-access-key: Enforce that the accessKey prop is not used on any element to avoid complications with keyboard commands used by a screenreader.
  • no-marquee: Enforce <marquee> elements are not used.
  • no-onchange: Enforce that onBlur is used instead of onChange.
  • onclick-has-focus: Enforce that elements with onClick handlers must be focusable.
  • onclick-has-role: Enforce that non-interactive, visible elements (such as <div>) that have click handlers use the role attribute.
  • role-has-required-aria-props: Enforce that elements with ARIA roles must have all required attributes for that role.
  • role-supports-aria-props: Enforce that elements with explicit or implicit roles defined contain only aria-* properties supported by that role.
  • scope: Enforce scope prop is only used on <th> elements.
  • tabindex-no-positive: Enforce tabIndex value is not greater than zero.

License

eslint-plugin-jsx-a11y is licensed under the MIT License.

About

Static AST checker for a11y rules on JSX elements.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%