返回在打字稿中反应16个数组元素

时间:2017-10-09 09:49:45

标签: javascript reactjs typescript jsx

我想使用新的react 16功能在我的<StackPanel x:Name="stackPanel">... 中返回数组元素,但我得到了打字稿错误render

Property 'type' is missing in type 'Element[]'

我缺少什么?使用 @ types / react 16.0.10 typescript 2.5.3

2 个答案:

答案 0 :(得分:6)

我检查了最新的打字,他们忘了在无状态组件界面中添加新定义。我提出了这个问题,应尽快解决。

从类组件返回一个数组是有效的,所以如果你现在真的需要它,你可以将你的功能组件转换为类组件。

class Elements extends React.Component<{}> {

  render() {
    return [
       <div key="a"></div>,
       <div key="b"></div>
    ]

  }
}

或使用模块扩充暂时扩展React类型。只需将以下代码放在您的.ts文件中,并且typescript将自动检测定义中的更改。

declare module "react" {
  interface StatelessComponent<P = {}> {
    (props: P & { children?: ReactNode }, context?: any): ReactElement<any>[] | ReactElement<any> | null;
    propTypes?: ValidationMap<P>;
    contextTypes?: ValidationMap<any>;
    defaultProps?: Partial<P>;
    displayName?: string;
  }
}

答案 1 :(得分:2)

或使用React fragments

render() {
    return 
       <>
        <div key="a"></div>,
        <div key="b"></div>
       </>
}