Bet*_*com 33 javascript typescript reactjs
官方reactjs.org网站包含一个优秀的介绍性教程。
教程片段是用 JavaScript 编写的,我正在尝试将它们转换为 TypeScript。
我设法使代码正常工作,但对使用接口有疑问。
onClick 回调的正确“函数签名”应该是什么。
有没有办法用显式函数签名替换 IProps_Square 接口中的“any”关键字?
任何帮助或建议将不胜感激,非常感谢罗素
索引.html
<!DOCTYPE html>
<html lang="en">
<body>
<div id="reactjs-tutorial"></div>
</body>
</html> 
索引.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')   
); 
Gia*_*ati 53
带有道具的界面应该是
interface IProps_Square {
  message: string;
  onClick: React.MouseEventHandler<HTMLButtonElement>;
}
另请注意,如果您使用分号,则界面项分隔符是分号,而不是逗号。
有没有办法用显式函数签名替换 IProps_Square 接口中的“any”关键字
我只是() => voidie 一个不带参数的函数,你不在乎它是否返回任何东西。
import * as React from 'react';   
import * as ReactDOM from 'react-dom'; 
interface IProps_Square {
  message: string,
  onClick: () => void,
}
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')   
); 
| 归档时间: | 
 | 
| 查看次数: | 50321 次 | 
| 最近记录: |