ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

javascript – 如何在React中更新父状态?

2019-09-15 12:46:49  阅读:172  来源: 互联网

标签:javascript reactjs react-native web-deployment


我的结构如下:

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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有