React 事件绑定
因为类的办法默认不会绑定 this,因而在调用的时候如果遗记绑定,this 的值将会是 undefined。
通常如果不是间接调用,应该为办法绑定 this。绑定形式有以下几种:
1. 在构造函数中应用 bind 绑定 this
class Box extends React.Component {constructor(props) {super(props);
this.handleClick = this.handleClick.bind(this);
}
handleClick() {console.log('this is:', this);
}
render() {
return (<button onClick={this.handleClick}>
Click me
</button>
);
}
}
2. 在调用的时候应用 bind 绑定 this
class Box extends React.Component {handleClick() {console.log('this is:', this);
}
render() {
return (<button onClick={this.handleClick.bind(this)}>
Click me
</button>
);
}
}
3. 在调用的时候应用箭头函数绑定 this
class Box extends React.Component {handleClick() {console.log('this is:', this);
}
render() {
return (<button onClick={() => this.handleClick()}>
Click me
</button>
);
}
}
4. 应用属性初始化器语法绑定 this(实验性)
class Box extends React.Component {handleClick = () => {console.log('this is:', this);
}
render() {
return (<button onClick={this.handleClick}>
Click me
</button>
);
}
}
比拟
形式 2 和形式 3 都是在调用的时候再绑定 this。
- 长处:写法比较简单,当组件中没有 state 的时候就不须要增加类构造函数来绑定 this
- 毛病:每一次调用的时候都会生成一个新的办法实例,因而对性能有影响,并且当这个函数作为属性值传入低阶组件的时候,这些组件可能会进行额定的从新渲染,因为每一次都是新的办法实例作为的新的属性传递。
形式 1 在类构造函数中绑定 this,调用的时候不须要再绑定
- 长处:只会生成一个办法实例,并且绑定一次之后如果屡次用到这个办法也不须要再绑定。
- 毛病:即便不必到 state,也须要增加类构造函数来绑定 this,代码量多一点。。。
形式 4:利用属性初始化语法,将办法初始化为箭头函数,因而在创立函数的时候就绑定了 this。
- 长处:创立办法就绑定 this,不须要在类构造函数中绑定,调用的时候不须要再作绑定。联合了形式 1、形式 2、形式 3 的长处
- 毛病:目前依然是实验性语法,须要用 babel 转译
总结
形式 1 是官网举荐的绑定形式,也是性能最好的形式。形式 2 和形式 3 会有性能影响并且当办法作为属性传递给子组件的时候会引起重渲问题。形式 4 目前属于实验性语法,然而是最好的绑定形式,须要联合 bable 转译