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.