对于React类组件this指向的简单总结

根据React中类组件的内部原理可知,React的类组件由React对其进行实例化,所以在React类组件内部的this指向都是当前组件的实例化对象。

但是,在做事件处理的时候,类内部自定义的普通函数的this却又指向了undefined

这是因为React的事件处理相当于一个赋值函数,以onClick={this.handleClick}为例,其过程是onClick通过this找到了原型链上的handleClick函数,当onClick被触发的时候,直接执行handleClick相当于handleChlick()

由于是一个普通function,又因为该方法位于类内部自动开启严格模式,所以当前方法的this就指向了undefined

为了解决这个问题,要使用bind()将该方法绑定给指向类组件实例对象的this
this.handleClick.bind(this)
为什么使用bind():bind的第一个参数会作为原函数运行时的this指向

还有一种解决方法,就是使用箭头函数,由于箭头函数没有自身的this指向,所以它会调用外层的this,也就是类的实例化对象
handleClick = () => {}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值