详解react关于事件绑定this的四种方式
程序员文章站
2022-09-26 13:59:22
在react组件中,每个方法的上下文都会指向该组件的实例,即自动绑定this为当前组件,而且react还会对这种引用进行缓存,以达到cpu和内存的最大化。在使用了es6 c...
在react组件中,每个方法的上下文都会指向该组件的实例,即自动绑定this为当前组件,而且react还会对这种引用进行缓存,以达到cpu和内存的最大化。在使用了es6 class或者纯函数时,这种自动绑定就不复存在了,我们需要手动实现this的绑定
react事件绑定类似于dom事件绑定,区别如下:
1.react事件的用驼峰法命名,dom事件事件命名是小写
2.通过jsx,传递一个函数作为event handler,而不是一个字符串。
3.react事件不能通过返回false来阻止默认事件,需要显式调用preventdefault()
如下实例:
<a href="#" onclick="console.log('the link was clicked.'); return false"> click me </a> class actionlink extends react.component { constructor(props) { super(props); } handleclick(e) { e.preventdefault(); console.log('the link was clicked.'); } render() { return ( <a href="#" onclick={this.handleclick.bind(this)}>click me...</a> ); } }
ps:react组件类的方法没有默认绑定this到组件实例,需要手动绑定。
以下是几种绑定的方法:
bind方法
直接绑定是bind(this)来绑定,但是这样带来的问题是每一次渲染是都会重新绑定一次bind;
class home extends react.component { constructor(props) { super(props); this.state = { }; } del(){ console.log('del') } render() { return ( <div classname="home"> <span onclick={this.del.bind(this)}></span> </div> ); } }
构造函数内绑定
在构造函数 constructor 内绑定this,好处是仅需要绑定一次,避免每次渲染时都要重新绑定,函数在别处复用时也无需再次绑定
class home extends react.component { constructor(props) { super(props); this.state = { }; this.del=this.del.bind(this) } del(){ console.log('del') } render() { return ( <div classname="home"> <span onclick={this.del}></span> </div> ); } }
::不能传参
如果不传参数使用双冒号也是可以
class home extends react.component { constructor(props) { super(props); this.state = { }; } del(){ console.log('del') } render() { return ( <div classname="home"> <span onclick={::this.del}></span> </div> ); } }
箭头函数绑定
箭头函数不仅是函数的'语法糖',它还自动绑定了定义此函数作用域的this,因为我们不需要再对它们进行bind方法:
class home extends react.component { constructor(props) { super(props); this.state = { }; } del=()=>{ console.log('del') } render() { return ( <div classname="home"> <span onclick={this.del}></span> </div> ); } }
以上几种方法都可以实现this绑定,使用那种各自的习惯;希望对大家的学习有所帮助,也希望大家多多支持。