@typescript-eslint/no-unused-vars false positive in type declarations(@tyescript-eslint/no-unuse-vars类型声明中的假阳性)
问题描述
@typescript-eslint/no-unused-vars.有一个问题 因此,我们有类型
type SomeType = (name: string) => void;
并且我们在类型声明的字符串中出现@typescript-eslint/no-unused-vars错误,它表明‘name’已定义但从未使用。
类型用法示例:
export const LogSomeInfo: SomeType = (name: string) => {
const a = name;
console.log(a);
};
或:
interface CheckboxPropsType {
value: string,
onClick(value: string): void
}
和eslint在onClick中断...字符串,表示该值已定义但从未使用过。 即使类型分配正确并且实际的onClick处理程序使用该值!
问题:该规则有什么问题?为什么会在这种情况下触发。为什么eslint将类型/接口中函数的类型声明识别为常规函数?我的eslint配置有问题吗?
";eslint";:";^7.7.0";, ";@typescript-eslint/eslint-plugin";:;^3.6.1&q;, ";@type-eslint/parser";:^4.0.1";, ";eslint-config-airbnb-tyescript";:";^9.0.0";,
{
"extends": [
"airbnb-typescript",
"airbnb/hooks",
"plugin:react/recommended",
"plugin:@typescript-eslint/recommended"
],
"parser": "@typescript-eslint/parser",
"parserOptions": {
"ecmaFeatures": {
"jsx": true
},
"ecmaVersion": 2018,
"sourceType": "module",
"project": "./tsconfig.json"
},
"settings": {
"react": {
"version": "detect"
}
},
"plugins": ["@typescript-eslint", "react-hooks", "react"],
"env": {
"browser": true
},
"rules": {
"object-curly-newline": 0,
"import/named": ["error"],
"indent": ["error", 4],
"react/jsx-indent": ["error", 4],
"comma-dangle": ["error", "never"],
"import/prefer-default-export": "off",
"react/jsx-fragments": "off",
"arrow-body-style": "off",
"object-curly-spacing": "off",
"@typescript-eslint/indent": ["error", 4, {"SwitchCase": 1}],
"@typescript-eslint/explicit-module-boundary-types": "off",
"no-undef": "error",
"react/jsx-indent-props": ["error", 4],
"max-len": ["error", { "code": 120 }],
"react/prop-types": "off"
}
}
推荐答案
前面提出的类似问题检查:Why ESLint throws 'no-unused-vars' for TypeScript interface?
禁用'@typescript-eslint/no-unused-vars': 0
规则,改用tsconfig.json中的"strict": true
、"noUnusedLocals": true
和"noUnusedParameters": true
这篇关于@tyescript-eslint/no-unuse-vars类型声明中的假阳性的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:@tyescript-eslint/no-unuse-vars类型声明中的假阳性
基础教程推荐
- 悬停时滑动输入并停留几秒钟 2022-01-01
- 动态更新多个选择框 2022-01-01
- 响应更改 div 大小保持纵横比 2022-01-01
- 在for循环中使用setTimeout 2022-01-01
- 在 JS 中获取客户端时区(不是 GMT 偏移量) 2022-01-01
- 当用户滚动离开时如何暂停 youtube 嵌入 2022-01-01
- 我什么时候应该在导入时使用方括号 2022-01-01
- Karma-Jasmine:如何正确监视 Modal? 2022-01-01
- 角度Apollo设置WatchQuery结果为可用变量 2022-01-01
- 有没有办法使用OpenLayers更改OpenStreetMap中某些要素 2022-09-06