logoESLint React

Migrating from eslint-plugin-react-hooks

Complete guide for migrating from eslint-plugin-react-hooks to ESLint React

This guide provides a comprehensive comparison between eslint-plugin-react-hooks and ESLint React rules to help you migrate your existing configuration.

Overview

ESLint React provides direct equivalents for the core rules in eslint-plugin-react-hooks, including both the classic hooks linting rules (exhaustive-deps, rules-of-hooks) and many of the newer React Compiler diagnostic rules introduced in the latest versions of the plugin.

Rules specific to the React Compiler runtime (such as config, gating, incompatible-library, and preserve-manual-memoization) do not have equivalents in ESLint React, as they validate compiler-specific configuration and behavior.

Rule Comparison Table

Legend

  • ๐Ÿ”ง Fully supported - Rule is supported, and has an auto-fix
  • ๐ŸŸข Mostly supported - Rule is supported but doesn't have an auto-fix
  • ๐ŸŸก Partial support - Similar but not identical functionality
  • ๐Ÿ”ด Not supported - No equivalent rule
  • ๐Ÿงช Experimental - Rule is supported but marked as experimental

Table

The following table compares all rules from eslint-plugin-react-hooks with their ESLint React equivalents:

eslint-plugin-react-hooks Rule NameNew Rule NamePrev StatusStatus
exhaustive-depsexhaustive-deps๐ŸŸข๐Ÿ”ง
rules-of-hooksrules-of-hooks๐ŸŸข๐Ÿ”ง
config๐ŸŸข๐Ÿ”ด
error-boundarieserror-boundaries๐ŸŸข๐ŸŸข
gating๐ŸŸข๐Ÿ”ด
globalsglobals๐ŸŸข๐ŸŸก ๐Ÿงช
immutabilityimmutability๐ŸŸข๐ŸŸก ๐Ÿงช
incompatible-library๐ŸŸข๐Ÿ”ด
preserve-manual-memoization๐ŸŸข๐Ÿ”ด
puritypurity๐ŸŸข๐ŸŸก ๐Ÿงช
refsrefs๐ŸŸข๐ŸŸก ๐Ÿงช
set-state-in-effectset-state-in-effect๐ŸŸข๐ŸŸข
set-state-in-renderset-state-in-render๐ŸŸข๐Ÿงช
static-componentsstatic-components๐ŸŸข๐Ÿงช
unsupported-syntaxunsupported-syntax๐ŸŸข๐ŸŸข
use-memouse-memo๐ŸŸข๐ŸŸข

ESLint React Column

  • Rule names link to ESLint React documentation
  • Multiple rules separated by + indicate that together they provide equivalent functionality
  • Rules marked ๐Ÿงช are experimental and their behavior may change in future releases
  • Rules marked ๐Ÿ”ด are React Compiler-specific and have no equivalent in ESLint React

Migration Preset

ESLint React provides a preset to disable conflicting rules from eslint-plugin-react-hooks:

  • disable-conflict-eslint-plugin-react-hooks - Disables all rules from eslint-plugin-react-hooks that have equivalents in ESLint React (e.g., react-hooks/exhaustive-deps, react-hooks/rules-of-hooks, etc.)

This preset is useful when migrating from eslint-plugin-react-hooks to ESLint React, as it prevents rule conflicts while you transition your configuration.