简单的例子:
import * as React from 'react'
declare function getFish(x: any): any;
declare var Tank: any;
var Aquarium = ({species}) => (
<Tank>
{getFish(species)}
</Tank>
);
let x = <Aquarium species="rainbowfish"/>;
结果:
(10,9):错误 TS2605:JSX 元素类型“元素”不是 JSX 元素的构造函数。
请注意,错误与组件的使用有关(let x 声明)。似乎 React 的定义文件不允许这是一个有效的 JSX?我正在使用来自 tsd 的最新 React 0.14 定义文件,我做错了什么?
假设我已经定义了以下无状态功能组件(React v0.14)
let GreeterComponent = (props: {name: string}){
return <div>Hi {props.name}!</div>
}
在不同的组件中,我这样使用它:
class WrappingComponent extends React.Component{
render(){
let names = ['tom', 'john', 'simon'];
return (
<div className="names">
{names.map((name)=> <GreeterComponent name={name} />)}
</div>
);
}
}
我从打字稿编译器收到此错误:
错误 TS2605:JSX 元素类型“元素”不是 JSX 元素的构造函数。“元素”类型中缺少属性“渲染”。
我该如何解决?在打字稿中使用无状态功能组件的正确方法是什么?我正在使用来自 tsd的最新react.d.ts