【发布时间】:2020-06-11 15:26:36
【问题描述】:
我正在尝试在使用 React Hooks 和 Styled 组件的 React Typescript 项目中创建自定义按钮组件。
// Button.tsx
import React, { MouseEvent } from "react";
import styled from "styled-components";
export interface IButtonProps {
children?: React.ReactNode;
props?: any;
onClick?:
| ((event: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void)
| undefined;
}
const Button: React.FC<IButtonProps> = ({
children,
onClick = () => {},
...props
}) => {
const handleOnClick = (e: MouseEvent<HTMLButtonElement>) => {
onClick(e);
};
return (
<ButtonStyles onClick={handleOnClick} {...props}>
{children}
</ButtonStyles>
);
};
export default Button;
const ButtonStyles = styled.button``;
这是我要使用我的自定义按钮的组件
// Login.tsx
import React from "react";
import Button from "../../components/Generic/Button/Button";
const Login: React.FC = () => {
const clickMe = () => {
console.log("Button Clicks");
};
return (
<div>
<Button onClick={clickMe}>My Button</Button>
</div>
);
};
export default Login;
我想单击我的自定义按钮,并希望在单击它时打印控制台日志消息。但我收到以下错误。如何解决这个问题?
Argument of type 'MouseEvent<HTMLButtonElement, MouseEvent>' is not assignable to parameter of type 'MouseEvent<HTMLButtonElement, MouseEvent<Element, MouseEvent>>'.
Type 'MouseEvent' is missing the following properties from type 'MouseEvent<Element, MouseEvent>': nativeEvent, isDefaultPrevented, isPropagationStopped, persist TS2345
16 | }) => {
17 | const handleOnClick = (e: MouseEvent<HTMLButtonElement>) => {
> 18 | onClick(e);
| ^
19 | };
20 | return (
21 | <ButtonStyles onClick={handleOnClick} {...props}>
【问题讨论】:
-
我相信您的
clickMe方法缺少事件参数。尝试将其更改为clickMe(e)。 -
@kaveh 我认为您的意思是: ,但仍然出现错误。
-
不,我的意思是您实际创建
clickMe的位置,所以const clickMe = () => {...}应该是const clickMe = (e) => {...} -
不,效果不佳。
标签: reactjs typescript react-hooks