Frequently Asked Questions

Why create eslint-react?

The existing eslint-plugin-react is a plugin for react-dom but named react¹, it only supports React DOM² and does not being expected to be used with x-platform.

Although you can use it with other renderers, it will always assume that you are using the React DOM, even if you are working with a codebase that uses a different renderer. This can sometimes cause confusion and problems³.

Unfortunately, the maintainers of eslint-plugin-react refuse to change that.

Just as in Beyond the DOM we believe that the community will benefit from a renderer-agnostic and x-platform-supported plugin. This is also the initial motivation for creating eslint-react.

What is included in eslint-react?

Currently, it includes the following plugins:

  • @eslint-react/eslint-plugin - The main ESLint plugin package including all rules and config presets in this repository.
  • eslint-plugin-react-x - Core rules (renderer-agnostic, compatible with x-platform).
  • eslint-plugin-react-dom - DOM specific rules for React DOM.
  • eslint-plugin-react-web-api - Rules for interacting with Web APIs.
  • eslint-plugin-react-hooks-extra - Extra React Hooks rules.
  • eslint-plugin-react-naming-convention - Naming convention rules.

You can view our long-term plans on the roadmap.

Is there anything to note about migrating from eslint-plugin-react to eslint-react?

Please be aware that some rules may behave differently when transitioning to eslint-react. The rules in eslint-react are more closely aligned with the guidelines provided by react.dev. This alignment is due to eslint-react adopting react.dev as its primary reference, rather than eslint-plugin-react.

To smoothly transition, we suggest reviewing the rules in eslint-react and running a comprehensive linting check on your codebase to identify and address any discrepancies introduced by the migration.