React重渲染时的浅拷贝

React的有状态组件在state发生变化时会重渲染,
重渲染过程为:state变化-->shouldComponentUpdate/ComponentWillReceiveProps-->componentWillUpdate-->render-->componentDidUpdate。

react进入重渲染的判定依据是state对象属性值的浅比对,如果我们需要深比对state属性值重渲染,该怎么解决呢?

比如

this.state={
type:0,
personnal:{
    name:"Tom",
    age:16
 }
}
复制代码

改为

this.state={
type:0,
personnal:{
    name:"Tom",
    age:20
 }
}
复制代码

此时,只改变personnal对象中的age属性值,react机制判断此次变化不会进入shouldComponentUpdate/ComponentWillReceiveProps。

我们加入一个开关变量personnalChange,作为personnal对象变化时的重渲染开关。

this.state={
type:0,
personnal:{
    name:"Tom",
    age:16
 },
 personnalChange:0
}
复制代码

在改变personnal属性值时,同时改变开关变量personnalChange,通过浅拷贝让react知道personnal对象发生了变化,从而进行重渲染。

this.setState({
    personnal:{
    name:"Tom",
    age:20
 },
 personnalChange:!this.state.personnalChange
})
复制代码

此时,personnalChange变化后进入shouldComponentUpdate/ComponentWillReceiveProps,在钩子函数中进行业务逻辑的处理和重渲染。

shouldComponentUpdate(nextProps,nextState){
    if(this.state.personnalChange!==nextState.personnalChange){
        //业务逻辑
        ....
        //重渲染
        return true
    }
}
复制代码

通过开关变量personnalChange实现personnal对象变化时的重渲染。

转载于:https://juejin.im/post/5c3bea71e51d455243765668

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值