Max*_*xPY 12 typescript reactjs eslint
我正在尝试设置一个typescript-react-eslint
项目并且无法通过此样板组件的 eslint 错误:
import * as React from "react";
interface ButtonProps {
children?: React.ReactNode,
onClick?: (e: any) => void,
}
const styles = {
border: "1px solid #eee",
borderRadius: 3,
backgroundColor: "#FFFFFF",
cursor: "pointer",
fontSize: 15,
padding: "3px 10px",
margin: 10
};
const Button: React.FunctionComponent<ButtonProps> = props => (
<button onClick={props.onClick} style={styles} type="button">
{props.children}
</button>
);
Button.defaultProps = {
children: null,
onClick: () => {}
};
export default Button;
Run Code Online (Sandbox Code Playgroud)
错误是:
19:26 error 'onClick' is missing in props validation react/prop-types
20:12 error 'children' is missing in props validation react/prop-types
Run Code Online (Sandbox Code Playgroud)
似乎是在抱怨<button>
未定义html 的接口?否则它可能是Button
组件本身,但它不应该从<ButtonProps>
我传递的接口中获取类型信息吗?
我尝试明确设置children
并onClick
像这样:
Button.propTypes = {
children?: React.ReactNode,
onClick?: (e: any) => void
};
Run Code Online (Sandbox Code Playgroud)
它绕过了 eslint 错误,但组件本身停止工作。我究竟做错了什么?
PS这是我的 .eslintrc.json
{
"env": {
"browser": true,
"commonjs": true,
"es6": true
},
"extends": [
"eslint:recommended",
"plugin:react/recommended",
"plugin:@typescript-eslint/eslint-recommended"
],
"globals": {
"Atomics": "readonly",
"SharedArrayBuffer": "readonly"
},
"settings": {
"react": {
"pragma": "React",
"version": "detect"
}
},
"parser": "@typescript-eslint/parser",
"parserOptions": {
"ecmaFeatures": {
"jsx": true
},
"ecmaVersion": 2018,
"sourceType": "module"
},
"plugins": [
"react",
"@typescript-eslint"
],
"rules": {
"indent": [
"error",
2
],
"linebreak-style": [
"error",
"unix"
],
"quotes": [
"error",
"double"
],
"semi": [
"error",
"always"
]
}
}
Run Code Online (Sandbox Code Playgroud)
Joã*_*spo 20
此规则对于 TypeScript 没有意义,因为您已经在检查类型。
在这个问题中,您找到了禁用此规则的简单方法,只需添加到您的 eslint 配置中:
rules: {
'react/prop-types': 0
}
Run Code Online (Sandbox Code Playgroud)
为了更具可读性,您可以使用“off”而不是“0”。
Max*_*xPY 12
我最终将组件重写为:
const Button = ({ children, onClick }: ButtonProps) => {
return <button onClick={onClick} style={styles} type="button">
{children}
</button>;
};
Run Code Online (Sandbox Code Playgroud)
这: React.FC<ButtonProps>
部分被 eslint 忽略了,所以我决定以更直接的方式提供 prop 类型
小智 6
eslint-plugin-react@^7.25.0
似乎已经解决了React.FC<IProps>
使用验证规则的问题react/prop-types
。
所以而不是
const Example: React.FC<IProps> = (props: IProps) => ...
Run Code Online (Sandbox Code Playgroud)
现在更新后不会出现警告
const Example: React.FC<IProps> = (props) => ...
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
10510 次 |
最近记录: |