对于孩子与父母的通信,您应该传递一个将状态从父母设置为孩子的函数,如下所示
class Parent extends React.Component { constructor(props) { super(props) this.handler = this.handler.bind(this) } handler() { this.setState({ someVar: 'some value' }) } render() { return <Child handler = {this.handler} /> }}class Child extends React.Component { render() { return <Button onClick = {this.props.handler}/ > }}这样,孩子可以通过调用通过props传递的函数来更新父母的状态。
但是您将不得不重新考虑组件的结构,因为据我了解,组件5和3并不相关。
一种可能的解决方案是将它们包装在更高级别的组件中,该组件将同时包含组件1和3的状态。此组件将通过prop设置较低级别的状态。



