前端成长之路(二)令人崩溃的static

本文深入探讨了React中static关键字的使用及限制,特别是在static方法内调用setState的问题。阐述了static方法属于类而非实例,因此无法访问组件的props、state,调用setState将导致错误。并介绍了如何在组件中正确调用静态方法。

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

前一段帮人解决一个bug,用了static,出现了this is undefined的错误,所以特地纠结了一下static的具体用法

the methods do not have access to the props or state of your components.
React默认不能通过static修改state。

一. 区分类和实例

static方法属于类,而setState是对象的方法,所以在static function内使用this会报错。static创建了一个属于类的方法或者属性,而不属于任何实例。

组件是类的一个实例,component的props和state都属于实例。

static function stateTest (){
  this.setState({   //报错

  })
}

setState作为对象的方法,在类方法中调用对象方法,因为无法确定类中有多少个对象,所以会找不到this

二. 组件中调用静态方法

class stateComponent extends React.Component {
   static function stateTest (){
   }
   ....
   // 调用
   stateComponent.stateTest() 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值