首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >(事件: MouseEvent<Element,MouseEvent>) => void‘不能分配到键入'() =>事件’

(事件: MouseEvent<Element,MouseEvent>) => void‘不能分配到键入'() =>事件’
EN

Stack Overflow用户
提问于 2019-02-05 15:20:49
回答 2查看 16.9K关注 0票数 7

这看起来很简单,但我无法处理这个问题--我总是在控制台中得到相同的消息:

类型错误:类型‘(事件: MouseEvent) => void’不能分配给键入'() =>事件‘。TS2322

这是我的密码:

代码语言:javascript
复制
//in one class  
//some code 
render() 
    return (
        <div className={keyStyle} key={key} onClick={() => this.props.turnKey()}></div>
    )

//in other classs
//some code
    return (
       <div className="container">
          <Display />
          <Keys turnKey={this.activateKey}/>
       </div>
    );
  }

  activateKey = (event : React.MouseEvent): void =>{
      console.log(event.target);
  }

如何解决此错误?

EN

回答 2

Stack Overflow用户

发布于 2019-02-05 15:26:09

您没有将event (这是必要的)传递给您的this.props.turnKey。我建议您以如下方式传递this.props.turnKey

代码语言:javascript
复制
<div className={keyStyle} key={key} onClick={this.props.turnKey}>

也许它能解决你的问题。

如果不是,那么支柱this.props.turnKey的声明就会出现一些问题。可能,你是这样宣布的

代码语言:javascript
复制
turnKey: () => Event

而不是

代码语言:javascript
复制
turnKey: (event: React.MouseEvent) => void
票数 9
EN

Stack Overflow用户

发布于 2021-04-26 11:38:43

关于event.target的问题: TS2532: Object可能是“未定义的”。

您可以将目标声明为HTMLDivElement。因此

代码语言:javascript
复制
  activateKey = (event : React.MouseEvent): void =>{
    const clickedElement = event.target as HTMLDivElement;
    console.log(clickedElement.value); // ot whatever you need
  }

应该能起作用。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54537652

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档