由于类的方法默认不会绑定this,所以在调用的时候需要手动绑定this,绑定this的几种方法
1,在构造函数中通过bind绑定this
class ReactHandle extends React.PrueComponent{
constructor(props){
this.handler=this.handler.bind(this)
}
bandler(){
console.log('在构造函数中通过bind绑定this')
}
render(){
return <div onClick={this.bandler}>
在构造函数中通过bind绑定this
</div>
}
}
2,在调用时通过bind绑定this
class ReactHandle extends React.PrueComponent{ bandler(){
console.log('在构造函数中通过bind绑定this')
}
render(){
return <div onClick={this.bandler.bind(this)}>
在构造函数中通过bind绑定this
</div>
}
}
3,在调用时通过箭头函数绑定this
class ReactHandle extends React.PrueComponent{ bandler(){
console.log('在构造函数中通过bind绑定this')
}
render(){
return <div onClick={()=>this.bandler()}>
在构造函数中通过bind绑定this
</div>
}
}
4,使用新的实验性方法
class ReactHandle extends React.PrueComponent{ bandler=()=>{
console.log('在构造函数中通过bind绑定this')
}
render(){
return <div onClick={this.bandler}>
在构造函数中通过bind绑定this
</div>
}
}
比较
**(2)和(3)**都是在调用的时候再绑定this。
- **优点:**当组件中没有state的时候就不需要添加类构造函数来绑定this
- **缺点:**每一次调用的时候都会生成一个新的方法实例,因此对性能有影响,并且当这个函数作为属性值传入低阶组件的时候,这些组件可能会进行额外的重新渲染,因为每一次都是新的方法实例作为的新的属性传递。
**(1)**在类构造函数中绑定this,调用的时候不需要再绑定
- **优点:**只会生成一个方法实例,并且绑定一次之后如果多次用到这个方法也不需要再绑定。
- **缺点:**即使不用到state,也需要添加类构造函数来绑定this,代码量多一点。。。
**(4):利用属性初始化语法,将方法初始化为箭头函数,因此在创建函数的时候就绑定了this。
优点:创建方法就绑定this,不需要在类构造函数中绑定,调用的时候不需要再作绑定。结合了(1)、(2)、(3)**的优点
**缺点:**需要用babel转译
总结
方式1是官方推荐的绑定方式,也是性能最好的方式。(2)和(3)会有性能影响并且当方法作为属性传递给子组件的时候会引起重渲问题。(4)目前属于实验性语法,但是是最好的绑定方式,需要结合bable转译