Rules
Overview
Linter rules can have false positives, false negatives, and some rules depend on the react or react-dom version you are using.
- 🌟 - Feature
- ⚙️ - Configurable
- 🧪 - Experimental
- 🐞 - Debug
- 💭 - Type Checking
- 🔧 - Fixable
- 🔄 - Codemod
- 0️⃣ - Severity 0
- 1️⃣ - Severity 1
- 2️⃣ - Severity 2
- ✅ - Severity in
recommended-typescriptandstrict-typescriptpresets
X Rules
The jsx-* rules check for issues exclusive to JSX syntax, which are absent from standard JavaScript (like handwritten createElement() calls).
| Rule | ✅ | 🌟 | Description | react |
|---|---|---|---|---|
jsx-dollar | 0️⃣ 0️⃣ | 🔧 | Prevents unnecessary dollar signs ($) from being inserted before an expression in JSX | |
jsx-key-before-spread | 1️⃣ 1️⃣ | 🧪 | Enforces that the key prop is placed before the spread prop in JSX elements | |
jsx-no-comment-textnodes | 1️⃣ 1️⃣ | Prevents comment strings (e.g., beginning with // or /*) from being accidentally inserted into the JSX element's textnodes | ||
jsx-no-duplicate-props | 0️⃣ 0️⃣ | Disallows duplicate props in JSX elements | ||
jsx-no-iife | 0️⃣ 2️⃣ | 🧪 | Disallows IIFE in JSX | |
jsx-no-undef | 0️⃣ 0️⃣ | Prevents using variables in JSX that are not defined in the scope | ||
jsx-shorthand-boolean | 0️⃣ 0️⃣ | 🔧 ⚙️ | Enforces the use of shorthand syntax for boolean attributes | |
jsx-shorthand-fragment | 0️⃣ 0️⃣ | 🔧 ⚙️ | Enforces the use of shorthand syntax for fragments | |
jsx-uses-react | 0️⃣ 0️⃣ | Marks React variables as used when JSX is used | ||
jsx-uses-vars | 0️⃣ 0️⃣ | Marks variables used in JSX elements as used | ||
no-access-state-in-setstate | 2️⃣ 2️⃣ | Disallows accessing this.state inside setState calls | ||
no-array-index-key | 1️⃣ 1️⃣ | Disallows an item's index in the array as its key | ||
no-children-count | 1️⃣ 1️⃣ | Disallows the use of Children.count from the react package | ||
no-children-for-each | 1️⃣ 1️⃣ | Disallows the use of Children.forEach from the react package | ||
no-children-map | 1️⃣ 1️⃣ | Disallows the use of Children.map from the react package | ||
no-children-only | 1️⃣ 1️⃣ | Disallows the use of Children.only from the react package | ||
no-children-prop | 0️⃣ 2️⃣ | Disallows passing children as a prop | ||
no-children-to-array | 1️⃣ 1️⃣ | Disallows the use of Children.toArray from the react package | ||
no-class-component | 0️⃣ 2️⃣ | Disallows class components except for error boundaries | ||
no-clone-element | 1️⃣ 1️⃣ | Disallows cloneElement | ||
no-component-will-mount | 2️⃣ 2️⃣ | 🔄 | Replaces usages of componentWillMount with UNSAFE_componentWillMount | >=16.3.0 |
no-component-will-receive-props | 2️⃣ 2️⃣ | 🔄 | Replaces usages of componentWillReceiveProps with UNSAFE_componentWillReceiveProps | >=16.3.0 |
no-component-will-update | 2️⃣ 2️⃣ | 🔄 | Replaces usages of componentWillUpdate with UNSAFE_componentWillUpdate | >=16.3.0 |
no-context-provider | 1️⃣ 1️⃣ | 🔄 | Replaces usages of <Context.Provider> with <Context> | >=19.0.0 |
no-create-ref | 2️⃣ 2️⃣ | Disallows createRef in function components | ||
no-default-props | 2️⃣ 2️⃣ | Disallows the defaultProps property in favor of ES6 default parameters | ||
no-direct-mutation-state | 2️⃣ 2️⃣ | Disallows direct mutation of this.state | ||
no-duplicate-key | 2️⃣ 2️⃣ | Disallows duplicate key on elements in the same array or a list of children | ||
no-forward-ref | 1️⃣ 1️⃣ | 🔄 | Replaces usages of forwardRef with passing ref as a prop | >=19.0.0 |
no-implicit-key | 1️⃣ 1️⃣ | 🧪 | Prevents key from not being explicitly specified (e.g., spreading key from objects) | |
no-leaked-conditional-rendering | 0️⃣ 0️⃣ | 💭 | Prevents problematic leaked values from being rendered | |
no-missing-component-display-name | 0️⃣ 0️⃣ | Enforces that all components have a displayName that can be used in devtools | ||
no-missing-context-display-name | 0️⃣ 0️⃣ | 🔧 | Enforces that all contexts have a displayName that can be used in devtools | |
no-missing-key | 2️⃣ 2️⃣ | Disallows missing key on items in list rendering | ||
no-misused-capture-owner-stack | 0️⃣ 2️⃣ | 🧪 | Prevents incorrect usage of captureOwnerStack | |
no-nested-component-definitions | 2️⃣ 2️⃣ | Disallows nesting component definitions inside other components | ||
no-nested-lazy-component-declarations | 2️⃣ 2️⃣ | Disallows nesting lazy component declarations inside other components | ||
no-prop-types | 2️⃣ 2️⃣ | Disallows propTypes in favor of TypeScript or another type-checking solution | ||
no-redundant-should-component-update | 2️⃣ 2️⃣ | Disallows shouldComponentUpdate when extending React.PureComponent | ||
no-set-state-in-component-did-mount | 1️⃣ 1️⃣ | Disallows calling this.setState in componentDidMount outside of functions such as callbacks | ||
no-set-state-in-component-did-update | 1️⃣ 1️⃣ | Disallows calling this.setState in componentDidUpdate outside of functions such as callbacks | ||
no-set-state-in-component-will-update | 1️⃣ 1️⃣ | Disallows calling this.setState in componentWillUpdate outside of functions such as callbacks | ||
no-string-refs | 2️⃣ 2️⃣ | 🔄 | Replaces string refs with callback refs | >=16.3.0 |
no-unnecessary-key | 0️⃣ 1️⃣ | 🧪 | Prevents key from being placed on non-top-level elements in list rendering | |
no-unnecessary-use-callback | 0️⃣ 1️⃣ | 🧪 | Disallows unnecessary usage of useCallback | |
no-unnecessary-use-memo | 0️⃣ 1️⃣ | 🧪 | Disallows unnecessary usage of useMemo | |
no-unnecessary-use-prefix | 1️⃣ 1️⃣ | 🧪 | Enforces that a function with the use prefix uses at least one Hook inside it | |
no-unsafe-component-will-mount | 1️⃣ 1️⃣ | Warns about the usage of UNSAFE_componentWillMount in class components | ||
no-unsafe-component-will-receive-props | 1️⃣ 1️⃣ | Warns about the usage of UNSAFE_componentWillReceiveProps in class components | ||
no-unsafe-component-will-update | 1️⃣ 1️⃣ | Warns about the usage of UNSAFE_componentWillUpdate in class components | ||
no-unstable-context-value | 0️⃣ 1️⃣ | Prevents non-stable values (i.e., object literals) from being used as a value for Context.Provider | ||
no-unstable-default-props | 0️⃣ 1️⃣ | ⚙️ | Prevents using referential-type values as default props in object destructuring | |
no-unused-class-component-members | 1️⃣ 1️⃣ | Warns about unused class component methods and properties | ||
no-unused-props | 0️⃣ 0️⃣ | 💭 🧪 | Warns about component props that are defined but never used | |
no-unused-state | 0️⃣ 1️⃣ | Warns about unused class component state | ||
no-use-context | 1️⃣ 1️⃣ | 🔄 | Replaces usages of useContext with use | >=19.0.0 |
no-useless-forward-ref | 1️⃣ 1️⃣ | Disallows useless forwardRef calls on components that don't use refs | ||
no-useless-fragment | 0️⃣ 1️⃣ | 🔧 ⚙️ | Disallows useless fragment elements | |
prefer-destructuring-assignment | 0️⃣ 1️⃣ | Enforces destructuring assignment for component props and context | ||
prefer-namespace-import | 0️⃣ 0️⃣ | 🔧 | Enforces importing React via a namespace import | |
prefer-read-only-props | 0️⃣ 0️⃣ | 💭 🧪 | Enforces read-only props in components | |
prefer-use-state-lazy-initialization | 1️⃣ 1️⃣ | Enforces wrapping function calls made inside useState in an initializer function |
DOM Rules
| Rule | ✅ | 🌟 | Description | react-dom |
|---|---|---|---|---|
no-dangerously-set-innerhtml | 1️⃣ 1️⃣ | Disallows dangerouslySetInnerHTML | ||
no-dangerously-set-innerhtml-with-children | 2️⃣ 2️⃣ | Disallows dangerouslySetInnerHTML and children at the same time | ||
no-find-dom-node | 2️⃣ 2️⃣ | Disallows findDOMNode | ||
no-flush-sync | 2️⃣ 2️⃣ | Disallows flushSync | ||
no-hydrate | 2️⃣ 2️⃣ | 🔄 | Replaces usages of ReactDom.hydrate() with hydrateRoot() | >=18.0.0 |
no-missing-button-type | 0️⃣ 1️⃣ | 🔧 | Enforces explicit type attribute for button elements | |
no-missing-iframe-sandbox | 0️⃣ 1️⃣ | 🔧 | Enforces explicit sandbox attribute for iframe elements | |
no-namespace | 2️⃣ 2️⃣ | Enforces the absence of a namespace in React elements | ||
no-render | 2️⃣ 2️⃣ | 🔄 | Replaces usages of ReactDom.render() with createRoot(node).render() | >=18.0.0 |
no-render-return-value | 2️⃣ 2️⃣ | Disallows the return value of ReactDOM.render | ||
no-script-url | 1️⃣ 1️⃣ | Disallows javascript: URLs as attribute values | ||
no-string-style-prop | 0️⃣ 0️⃣ | Disallows the use of string style prop in JSX. Use an object instead | ||
no-unknown-property | 0️⃣ 0️⃣ | 🔧 ⚙️ | Disallows unknown DOM property | |
no-unsafe-iframe-sandbox | 1️⃣ 1️⃣ | Enforces sandbox attribute for iframe elements is not set to unsafe combinations | ||
no-unsafe-target-blank | 0️⃣ 1️⃣ | 🔧 | Disallows target="_blank" without rel="noreferrer noopener" | |
no-use-form-state | 2️⃣ 2️⃣ | 🔄 | Replaces usages of useFormState with useActionState | >=19.0.0 |
no-void-elements-with-children | 2️⃣ 2️⃣ | Disallows children in void DOM elements | ||
prefer-namespace-import | 0️⃣ 0️⃣ | 🔧 | Enforces React DOM is imported via a namespace import |
Web API Rules
| Rule | ✅ | 🌟 | Description |
|---|---|---|---|
no-leaked-event-listener | 1️⃣ 1️⃣ | Enforces that every addEventListener in a component or custom hook has a corresponding removeEventListener | |
no-leaked-interval | 1️⃣ 1️⃣ | Enforces that every setInterval in a component or custom hook has a corresponding clearInterval | |
no-leaked-resize-observer | 1️⃣ 1️⃣ | Enforces that every ResizeObserver created in a component or custom hook has a corresponding ResizeObserver.disconnect() | |
no-leaked-timeout | 1️⃣ 1️⃣ | Enforces that every setTimeout in a component or custom hook has a corresponding clearTimeout |
Hooks Extra Rules
This section contains rules that are not part of the official eslint-plugin-react-hooks plugin but are useful for specific use cases or patterns.
| Rule | ✅ | 🌟 | Description |
|---|---|---|---|
no-direct-set-state-in-use-effect | 1️⃣ 1️⃣ | 🧪 | Disallows direct calls to the set function of useState in useEffect |
Naming Convention Rules
| Rule | ✅ | 🌟 | Description |
|---|---|---|---|
component-name | 0️⃣ 0️⃣ | ⚙️ | Enforces naming conventions for components |
context-name | 1️⃣ 1️⃣ | Enforces context name to be a valid component name with the suffix Context | |
filename | 0️⃣ 0️⃣ | ⚙️ | Enforces consistent file naming conventions |
filename-extension | 0️⃣ 0️⃣ | ⚙️ | Enforces consistent use of the JSX file extension |
use-state | 1️⃣ 1️⃣ | ⚙️ | Enforces destructuring and symmetric naming of useState hook value and setter |
Debug Rules
The eslint-plugin-react-debug package is not included in the unified plugin. You need to install and configure it separately.
These rules are useful for code metrics, code transformation, issue reporting, or when building custom tooling that needs to identify specific React patterns.
| Rule | 🌟 | Description |
|---|---|---|
class-component | 🐞 | Reports all class components in json format |
function-component | 🐞 | Reports all function components in json format |
hook | 🐞 | Reports all react hooks in json format |
is-from-react | 🐞 | Reports all identifiers that are initialized from React in json format |
jsx | 🐞 | Reports all JSX elements and fragments in json format |