javascript - ReactJS 中 onClick 事件的 TypeScript 接口(interface)签名

标签 javascript reactjs typescript

官方reactjs.org网站包含出色的介绍性教程。

教程片段是用 JavaScript 编写的,我正在尝试将它们转换为 TypeScript。

我已经设法使代码正常工作,但对使用接口(interface)有疑问。

onClick 回调的正确“函数签名”应该是什么。

有没有办法用显式函数签名替换 IProps_Square 接口(interface)中的“any”关键字?

非常感谢任何帮助或建议,非常感谢 Russell

index.html

<!DOCTYPE html>
<html lang="en">
<body>
<div id="reactjs-tutorial"></div>
</body>
</html> 

index.tsx

import * as React from 'react';   
import * as ReactDOM from 'react-dom'; 

interface IProps_Square {
  message: string,
  onClick: any,
}

class Square extends React.Component < IProps_Square > {
   render() {  
     return (
       <button onClick={this.props.onClick}>
         {this.props.message}
       </button>
     );
   }
}

class Game extends React.Component {
  render() {
    return (
      <Square
         message = { 'click this' }
         onClick = { () => alert('hello') }
      />
    );
  }
}

ReactDOM.render(
  <Game />, 
  document.getElementById('reactjs-tutorial')   
); 

最佳答案

带有 props 的接口(interface)应该是

interface IProps_Square {
  message: string;
  onClick: React.MouseEventHandler<HTMLButtonElement>;
}

另请注意,如果您使用分号,则界面项分隔符是分号,而不是逗号。

关于javascript - ReactJS 中 onClick 事件的 TypeScript 接口(interface)签名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54433183/

相关文章:

javascript - ReactJs componentDidMount 执行两次

typescript - Typescript 构造函数中的公共(public)与私有(private)

javascript - Angular 2检索选定的复选框

javascript - 如何防止值不超过 5 个字符?

javascript - 将菜单悬停更改为单击/事件 CSS

json - 迭代渲染中的嵌套 json 对象数组 (ReactJS)

javascript - 避免在 react redux 中无法读取未定义的属性 'map'

Angular loadChildren 属性模块的绝对路径不起作用

javascript - Angular:表单控件的指令变换值

javascript - AJAX SEO - 后退和前进按钮