react-严格模式

严格模式
StrictMode(React.StrictMode),本质是一个组件,该组件不会进行UI渲染,它的作用是在渲染内部组件时,发现不合适的代码

  • 识别不安全的生命周期 (比如旧版生命周期被淘汰的componentWillMount)
  • 使用过时字符串refAPI的警告
  • 使用废弃的findDOMNode方法的警告
  • 检测意外的副作用(除了函数副作用的三点还有改变参数值和调用setState)
  • 检测过时的context API (比如 childContextTypes)

严格模式无法自动检测出具有副作用的代码,因此
在严格模式下(开发阶段),组件的生命周期会被调用两次,以此来明显化副作用代码

注意: 在React17中,React会自动修改console.log方法,在第二次调用生命周期函数时,将会静默输出
在React18中,React将不会抑制任何日志,如果你安装了devtools,第二次输入将会被淡化,在devtools工具中可以屏蔽第二次输出
还要注意一下,由于componentDidMount等函数会被放入执行队列,所以就算关闭了第二次输出,函数里面的打印在严格模式下还是会输出两次

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

合法的咸鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值