javascript – 如何在React中更新父状态?
作者:互联网
我的结构如下:
Component 1
- |- Component 2
- - |- Component 4
- - - |- Component 5
Component 3
组件3应根据组件5的状态显示一些数据.
由于道具是不可变的,我不能简单地在组件1中保存它的状态并转发它,对吗?是的,我读过有关redux的内容,但不想使用它.我希望只有反应就可以解决它.我错了吗?
解决方法:
对于子父通信,您应该传递一个函数,将状态从父级设置为子级,就像这样
class Parent extends React.Component {
constructor(props) {
super(props)
this.handler = this.handler.bind(this)
}
handler(someValue) {
this.setState({
someVar: someValue
})
}
render() {
return <Child handler = {this.handler} />
}
}
class Child extends React.Component {
render() {
return <Button onClick = {this.props.handler}/ >
}
}
这样,孩子可以通过调用带有props传递的函数来更新父级的状态.
但是你必须重新考虑组件的结构,因为据我所知,组件5和3不相关.
一种可能的解决方案是将它们包装在更高级别的组件中,该组件将包含组件1和3的状态.该组件将通过props设置较低级别的状态.
标签:javascript,reactjs,react-native,web-deployment 来源: https://codeday.me/bug/20190915/1804760.html