通过props将父组件的当前状态传递给子组件

时间:2017-06-14 14:39:50

标签: javascript reactjs

我有一个非常事件驱动的组件。在这种情况下,它是一个视频标签,它将使用播放视频的当前状态更新其状态。为简单起见,想象它看起来像这样:

export default class VideoPlayer extends Component {
  state = {
    canPlay: false,
    duration: 0,
    position: 0,
  };

  onCanPlay = () => this.setState({ canPlay: true });
  onTimeUpdate = ({ target: { position, duration } }) => this.setState({ position, duration });

  render() {
    const { src, children } = this.props;

    return (
      <div className={styles.container}>
        <video
          src={src}
          onCanPlay={this.onCanPlay}
          onTimeUpdate={this.onTimeUpdate}
        />
        {children}
      </div>
    );
  }
}

在这种情况下,我想将组件的整个状态传递给子组件。我能做到的一种方式,感觉有点痉挛,就是传递一个函数作为注入状态并返回组件的子节点。例如:

{children(this.state)}

传入的组件如下:

{(state) => <Progress {...state} />}

但我觉得必须有一种方法可以隐式地将父组件的状态作为props传递。如何用React完成?

1 个答案:

答案 0 :(得分:1)

也许你可以试试:

<div>
   { React.Children.map(this.props.children,
                        child => React.cloneElement(child, {...this.state})
   )}
</div>