为什么有条件地使用react-hooks时 eslint-plugin-react-hooks 不会发出警告?

IT技术 reactjs eslint
2021-05-05 13:56:14

我正在使用 react 16.8 和 eslint-plugin-react-hooks 1.6.0 。当我有条件地使用钩子时,我希望 eslint 会警告我。这是我的配置:

"eslintConfig": {
    "parser": "babel-eslint",
    "plugins": [
      "react-hooks"
    ],
    "rules": {
      "react-hooks/rules-of-hooks": "error",
      "react-hooks/exhaustive-deps": "warn"
    }
}

如果我在自定义钩子中有条件地使用钩子,会出现这样的警告:“React Hook \”useState\” 有条件地调用。在每个组件渲染中,必须以完全相同的顺序调用 React Hooks。”

function useCustomHook() {
  if (Math.random() > 0.5){
    const [a, setA] = useState(0)
  }
}

但是如果我在函数组件中使用钩子,它就不起作用。

function MyComponent() {
  if (Math.random() > 0.5){
    const [a, setA] = useState(0)
  }
  return null
}
4个回答

这对我有用:

  1. 首先安装相应的 eslint 插件:
   $ npm i --save-dev eslint-plugin-react-hooks
  1. 将它与默认配置一起添加到您的 .eslintrc 中:
  {
    "plugins": [
      ...
      "react-hooks"
    ],
    "rules": {
      ...
      "react-hooks/rules-of-hooks": "error",
      "react-hooks/exhaustive-deps": "warn"
    }
    ...
  1. 安装 eslint 配置模板“react-app”:
  $ npm i --save-dev eslint-config-react-app
  1. 在您的 .eslintrc 中从新安装的配置扩展:
  {
    ...
    "extends": "react-app"
  1. 确保您拥有新包的正确对等依赖项,例如我必须执行以下操作:
  $ npm i --save-dev eslint-plugin-flowtype
  1. 确保你的 eslint 包是 5+ 版本,例如 5.16.0 工作,更高的也应该工作(但要注意更高的 eslint 也需要更新的 nodejs)。
  $ npm i --save-dev eslint@^5.0.0
  1. 重启 VSCode
  2. 按 Cmd-Shift-U 打开输出终端,在下拉菜单中切换到 Eslint 并检查它是否加载没有错误。

实际上,当我将您的函数粘贴到由 create-react-app 创建的 App.js 文件时,运行该应用程序时会出现预期错误。

也许你的函数不被认为是一个 React 组件(你的函数被认为是一个通用函数)。确保你在作用域上有 React ( import React from "react";)

你的 eslint 配置也对我不起作用,但这个配置:

"eslintConfig": {
  "extends": "react-app"
}

我增加了以下依存关系:@typescript-eslint/eslint-plugin@typescript-eslint/parserpackage.json并添加以下内容.eslintrc.js

extends: [... 'plugin:@typescript-eslint/recommended', 'plugin:react-hooks/recommended']
parser: '@typescript-eslint/parser',
plugins: [..., '@typescript-eslint'],