Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/EmptyTag/154.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 通过道具将父组件的当前状态传递给子组件_Javascript_Reactjs - Fatal编程技术网

Javascript 通过道具将父组件的当前状态传递给子组件

Javascript 通过道具将父组件的当前状态传递给子组件,javascript,reactjs,Javascript,Reactjs,我有一个非常事件驱动的组件。在这种情况下,它是一个视频标签,它将用播放视频的当前状态更新其状态。为了简单起见,想象一下它是这样的: export default class VideoPlayer extends Component { state = { canPlay: false, duration: 0, position: 0, }; onCanPlay = () => this.setState({ canPlay: true });

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

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>
    );
  }
}
其中传入的组件类似于:

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

但我觉得必须有一种方法将父组件的状态作为道具隐式传递。如何使用React完成此操作?

也许您可以尝试使用:

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

您不能隐式地完成这项工作,您可以使用{React.cloneElementchildren,{…this.state}吗?
<div>
   { React.Children.map(this.props.children,
                        child => React.cloneElement(child, {...this.state})
   )}
</div>