美文网首页
React事件处理函数this指向解析

React事件处理函数this指向解析

作者: txwslyf | 来源:发表于2017-11-24 16:16 被阅读0次

我们知道,由于浏览器的工作原理,事件处理函数当中的this都是指向当前的绑定了事件处理函数的DOM节点对象。但是一般在开发过程中我们都需要其内部的this指向的应该是这个组件的实例本身。常用的有以下三种方法:

方法一

export default class Test extends React.Component {
  constructor () {
    super()
    this.value = 1
    this.handleClick = this.handleClick.bind(this)
  }

  handleClick () {
    console.log(this.value)
  }

  render () {
    return <div>
      <button onClick={this.handleClick}>点我</button>
    </div>
  }
}

这种方法是由我们在构造函数中手动为事件处理函数硬绑定this。

方法二

export default class Test extends React.Component {
  constructor () {
    super()
    this.value = 1
  }

  handleClick () {
    console.log(this.value)
  }

  render () {
    return <div>
      <button onClick={this.handleClick.bind(this)}>点我</button>
    </div>
  }
}

这种方法其实和第一种应该是一样的,只不过绑定的位置发生了变化而已。

方法三

export default class Test extends React.Component {
  constructor () {
    super()
    this.value = 1
  }

  handleClick (e) {
    console.log(e)
    console.log(this.value)
  }

  render () {
    return <div>
      <button onClick={(e) => {
        this.handleClick(e)
      }}>点我
      </button>
    </div>
  }
}

第三种方法运用的是箭头函数内部this不可变性 (不可变性不是指箭头函数内部的 this永远指向一致,而是指其内部的 this永远指向箭头函数被定义时外部最近的 this

在这种情况下,由于事件处理函数是一个箭头函数,那没箭头函数内部的this指向就不可以被改变了,this指向离箭头函数最近的外部this,而render()方法中的this由于react的自动绑定机制,this指向实例本身,所以箭头函数的this也指向实例本身。而this.handleClick()这种调用方式其实和handleClick.apply(this)是等效的,所以这种写法也可以。

ES7的写法

export default class Test extends React.Component {
  constructor () {
    super()
    this.value = 1
  }

  handleClick = (e) => {
    console.log(e)
    console.log(this.value)
  }

  render () {
    return <div>
      <button onClick={this.handleClick}>点我</button>
    </div>
  }
}

不过,在Class中直接赋值是ES7的写法(其实和下面的写法等价),ES6并不支持,只用ES6的话可以用下面写法

export default class Test extends React.Component {
  constructor () {
    super()
    this.value = 1
    this.handleClick = (e) => {
      console.log(e)
      console.log(this.value)
    }
  }

  render () {
    return <div>
      <button onClick={this.handleClick}>点我</button>
    </div>
  }
}

总结

介绍了五种写法,总的来说可以分为两类,前三种是一类,后两种算一类。这两类最大的区别就是前者的事件处理函数是定义在类的原型之上,实现了代码的复用。而后者的事件处理函数是作为实例属性,每个类的实例在实例化时都需要定义一遍事件处理函数。

参考链接

相关文章

  • React事件处理函数this指向解析

    我们知道,由于浏览器的工作原理,事件处理函数当中的this都是指向当前的绑定了事件处理函数的DOM节点对象。但是一...

  • 好程序员分享React-010-事件处理函数的this指向问题

    好程序员分享React-010-事件处理函数的this指向问题,区分普通函数与事件处理函数 1、普通函数是直接调用...

  • this的关键字理解和指向

    普通函数中this指向的是window 事件处理函数中this指向事件源: 回调函数中this指向window: ...

  • React事件绑定this的几种方法

    React事件处理函数绑定this的集中方法 Follow me on GitHub React事件处理函数绑定t...

  • js函数防抖、节流实现

    React中使用防抖函数和节流函数 在React事件调用时,React传递给事件处理程序是一个合成事件对象的实例。...

  • 关于React的一些奇奇怪怪问题

    问题一:为什么React事件处理函数会丢失this? 写Class类型React组件时,大家都会记得要将事件函数绑...

  • JavaScript变幻莫测的上下文对象-this

    一、全局环境 this指向window 二、事件处理函数 事件函数中的this的两种情况 1、普通函数--谁调用t...

  • 2022-07-16

    07_事件处理 methods:事件配置项,里面的函数被vue管理,函数的this指向vm 或 组件实例对象 pr...

  • React基础

    React处理事件与DOM相似: React事件绑定采用驼峰形式,而不是小写 JSX语法传入的函数是{}里面放置函...

  • react 事件处理

    react 的事件处理和DOM的事件处理其实是比较像的,但是因为jsx更加偏向js,所以我们定义事件处理函数的时候...

网友评论

      本文标题:React事件处理函数this指向解析

      本文链接:https://www.haomeiwen.com/subject/fpkfbxtx.html