您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

React事件绑定的几种方法分享

2024/4/29 4:58:25发布21次查看
本文主要给大家介绍了关于react学习之事件绑定的几种方法对比,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,希望能帮助大家更深掌握react事件绑定的方法。
react事件绑定
由于类的方法默认不会绑定this,因此在调用的时候如果忘记绑定,this的值将会是undefined。
通常如果不是直接调用,应该为方法绑定this。绑定方式有以下几种:
1. 在构造函数中使用bind绑定this
class button 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 button extends react.component {  handleclick(){  console.log('this is:', this);  }  render() {  return (   <button onclick={this.handleclick.bind(this)}>   click me   </button>  );  } }
3. 在调用的时候使用箭头函数绑定this
class button extends react.component {  handleclick(){  console.log('this is:', this);  }  render() {  return (   <button onclick={()=>this.handleclick()}>   click me   </button>  );  } }
4. 使用属性初始化器语法绑定this(实验性)
class button 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转译
相关推荐:
jquery事件绑定功能基础讲解
详解jquery实现基本的事件绑定功能
详解es6中javascript实现函数绑定及类的事件绑定功能
以上就是react事件绑定的几种方法分享的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product