State & 生命周期

本文深入探讨React中状态管理的细节,包括state的初始化、更新及合并过程,阐述了构造函数、setState方法的使用,以及组件生命周期中的关键阶段如componentDidMount和componentWillUnmount。此外,还讲解了状态更新如何触发组件重新渲染,以及数据流在React组件间如何自顶向下的传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先看这张图

React çå½å¨æå¾è§£

react 中的钩子函数

componentDidMount() {}

componentWillUnmount() {}

state的使用

this.state.XXX,不会重新渲染组件

this.setState({})会重新渲染组件

构造函数是唯一能够初始化this.state的地方。

this.setState((prevState, props) => ({
  counter: prevState.counter + props.increment
}));
this.setState(function(prevState, props) {
  return {
    counter: prevState.counter + props.increment
  };
});

上面两段代码意思相同:设置counter的值为上一个状态的counter+increment,这里不能直接 写 counter:this.state.counter+increment

 

状态更新合并

当你调用 setState() 时,React 将你提供的对象合并到当前状态。

数据自顶向下流动

父组件或子组件都不能知道某个组件是有状态还是无状态,并且它们不应该关心某组件是被定义为一个函数还是一个类。

这就是为什么状态通常被称为局部或封装。 除了拥有并设置它的组件外,其它组件不可访问。

转载于:https://my.oschina.net/u/3643058/blog/3039209

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值