简体   繁体   English

误报 eslint(no-unused-vars)

[英]False Positive eslint(no-unused-vars)

Here you can see I have a very simple react component, but the eslint rule is giving me a false positive.在这里你可以看到我有一个非常简单的反应组件,但是 eslint 规则给了我一个误报。

在此处输入图片说明

Config Details配置详情

package.json包.json

"devDependencies": {
    "eslint": "^5.13.0",
    "eslint-plugin-react": "^7.12.4",
    "eslint-plugin-react-hooks": "^1.0.1",
}

.eslintrc.js .eslintrc.js

module.exports = {
    "env": {
        "browser": true,
        "es6": true
    },
    "extends": "eslint:recommended",
    "parserOptions": {
        "ecmaFeatures": {
            "jsx": true
        },
        "ecmaVersion": 2018,
        "sourceType": "module"
    },
    "plugins": [
        "react",
        "react-hooks"
    ],
    "rules": {
        "indent": [
            "error",
            2
        ],
        "linebreak-style": [
            "error",
            "unix"
        ],
        "quotes": [
            "error",
            "single"
        ],
        "semi": [
            "error",
            "never"
        ],
        "react-hooks/rules-of-hooks": "error"
    },
    "settings": {
        "react": {
            "createClass": "createReactClass", // Regex for Component Factory to use, default to "createReactClass"
            "pragma": "React",  // Pragma to use, default to "React"
            "version": "detect", // React version. "detect" automatically picks the version you have installed. You can also use `16.0`, `16.3`, etc, if you want to override the detected value.
        },
        "linkComponents": [
            // Components used as alternatives to <a> for linking, eg. <Link to={ url } />
            "Hyperlink",
            { "name": "Link", "linkAttribute": "to" }
        ]
    }
};

ESLint doesn't know React semantics for variable usage in JSX by default.默认情况下,ESLint 不知道 JSX 中变量使用的 React 语义。 To fix this, I could either enable the react/jsx-uses-vars rule or extend from plugin:react/recommended configuration.为了解决这个问题,我可以启用 react/jsx-uses-vars 规则或从 plugin:react/recommended 配置扩展。 I went with the latter.我和后者一起去了。

"extends": ["eslint:recommended", "plugin:react/recommended"]

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM