React监听窗口变化

本文介绍了React组件如何正确监听窗口变化,强调了改变事件方法中的`this`指向、添加监听以及注销事件的重要性。错误做法包括不在`constructor`中绑定`resizeTTY`的`this`,以及未在`componentWillUnmount`中移除监听,导致的错误和内存泄漏问题。

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

React组件监听窗口变化

基本思路:

改变事件方法中的this指向

constructor(props) {
  this.resizeBind = this.resizeTTY.bind(this)
}

添加监听

componentDidMount() {
  window.addEventListener('resize', this.resizeBind)
}

注销事件

componentWillUnmount() {
  window.removeEventListener('resize', this.resizeBind)
}

错误写法:

  • 不在constructor中绑定resizeTTY的this指向,这时resizeTTY中的this指向window而不是React组件,在resizeTTY中获取React组件的state或者使用setState方法会抛出错误:(socketList是state的属性)
Cannot read property 'socketList' of undefined
  • 尝试在constructor中用bind绑定this但不赋值给新函数,这时编译不再报错,但窗口变化时resizeTTY执行仍然抛出错误,这时输出this仍指向window对象
    这是因为bind()函数执行后会返回指定this改造后的原函数拷贝,但原函数不会改变,所以我们需要使用的是bind返回的新函数而不是resizeTTY
constructor(props) {
  this.resizeTTY.bind(this)
}
componentDidMount() {
  window.addEventListener('resize', this.resizeTTY)
}
componentWillUnmount() {
  window.removeEventListener('resize', this.resizeTTY)
}
Cannot read property 'socketList' of undefined
  • 不在componentWillUnmount生命周期中注销事件,会导致组件销毁后仍在监听
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值