React事件绑定:激情澎湃的绑定方式

摘要

React中,所有命名都采用小驼峰格式。例如,将onclick改为onClick非常容易。例如,以下代码段:class ShowAlert extends React.Component render() {return (

{alert(‘Hello World!’)}}>Show

);}}。

正文

一、是啥

react运用中,事情名全是用小骆驼峰文件格式开展撰写,比如onclick要改变成onClick

非常简单的事情关联以下:

class ShowAlert extends React.Component {
  showAlert() {
    console.log("Hi");
  }

  render() {
    return <button onClick={this.showAlert}>show</button>;
  }
}

从上边能够 见到,事情关联的方式必须 应用{}包起来

以上的编码看起来没有问题,可是当将处理函数輸出编码换为console.log(this)的情况下,点一下按键,则会发觉控制面板輸出undefined

二、怎样关联

为了更好地处理上边恰当輸出this的难题,普遍的关联方法有以下:

  • render方法中应用bind
  • render方法中应用箭头函数
  • constructor中bind
  • 界定环节应用箭头函数关联

render方法中应用bind

假如应用一个类部件,在这其中给某一部件/原素一个onClick特性,它如今并会自设关联其this到当今部件,处理这个问题的方式是在事情涵数后应用.bind(this)this关联到当今部件中

class App extends React.Component {
  handleClick() {
    console.log('this > ', this);
  }
  render() {
    return (
      <div onClick={this.handleClick.bind(this)}>test</div>
    )
  }
}

这类方法在部件每一次render3D渲染的情况下,都是会再次开展bind的实际操作,危害特性

render方法中应用箭头函数

根据ES6的前后文来将this的偏向关联给当今部件,一样在每一次render的情况下都是会转化成新的方式,危害特性

class App extends React.Component {
  handleClick() {
    console.log('this > ', this);
  }
  render() {
    return (
      <div onClick={e => this.handleClick(e)}>test</div>
    )
  }
}

constructor中bind

constructor中事先bind当今部件,能够 防止在render实际操作中反复关联

class App extends React.Component {
  constructor(props) {
    super(props);
    this.handleClick = this.handleClick.bind(this);
  }
  handleClick() {
    console.log('this > ', this);
  }
  render() {
    return (
      <div onClick={this.handleClick}>test</div>
    )
  }
}

界定环节应用箭头符号函数关联

跟以上方法三一样,可以防止在render实际操作中反复关联,完成也十分的简易,以下:

class App extends React.Component {
  constructor(props) {
    super(props);
  }
  handleClick = () => {
    console.log('this > ', this);
  }
  render() {
    return (
      <div onClick={this.handleClick}>test</div>
    )
  }
}

三、差别

以上四种方式的方法,差别关键以下:

  • 撰写层面:方法一、方法二书写简易,方法三的撰写过度繁杂
  • 特性层面:方法一和方法二在每一次部件render的情况下都是会转化成新的方式案例,特性难题缺乏。若该涵数做为特性值发送给子部件的情况下,都是会造成附加的3D渲染。而方法三、方法四只会转化成一个方式案例

综合性以上,方法四是最佳的事情关联方法

 

关注不迷路

扫码下方二维码,关注宇凡盒子公众号,免费获取最新技术内幕!

温馨提示:如果您访问和下载本站资源,表示您已同意只将下载文件用于研究、学习而非其他用途。
文章版权声明 1、本网站名称:宇凡盒子
2、本站文章未经许可,禁止转载!
3、如果文章内容介绍中无特别注明,本网站压缩包解压需要密码统一是:yufanbox.com
4、本站仅供资源信息交流学习,不保证资源的可用及完整性,不提供安装使用及技术服务。点此了解
5、如果您发现本站分享的资源侵犯了您的权益,请及时通知我们,我们会在接到通知后及时处理!提交入口
0

评论0

请先

站点公告

🚀 【宇凡盒子】全网资源库转储中心

👉 注册即送VIP权限👈

👻 全站资源免费下载✅,欢迎注册!

记得 【收藏】+【关注】 谢谢!~~~

立即注册
没有账号?注册  忘记密码?

社交账号快速登录