React——关于事件处理

如何注册事件

驼峰命名法,语法on+事件名={事件处理程序}

比如onClick={this.buttonClick}

js 复制代码
class App extends React.Component {
  render() {
    return (
      <div>
        <button onClick={this.buttonClick}>点击按钮触发事件</button>
      </div>
    )
  }
  buttonClick() {
      alert('事件触发')
  }
}
事件对象 (涉及阻止事件流 e.preventDefault())

通过事件处理程序的参数获取到事件对象

js 复制代码
function buttonClick(e) {
    e.preventDefault()
    console.log('事件对象', e)
}
// 比如阻止a标签调整的共呢个
<a onClick={this.buttonClick}>点击不调整,按钮样式</a>
this指向

关于React的this的指向,与我们JS的this指向原理是一致的,但为什么会丢失呢?这个是JS原本的缺陷。

this的指向坚持谁调用指向谁,我们可以通过react的源码看到render函数通过instance去调用的,那render内部的this指向肯定是instance;

如果我们在render函数内直接调用其他事件,它this的指向也会是instance;

如果我们在render return的虚拟dom的on事件当中注册事件的话,那this的指向会是undefined,因为是模块化环境,全局状态的this不是window而是undefined

那么为什么在vue框架里面不存在这个问题的呢?

vue实例里,我们所有方法都写在methods里面,我们通过源码可以发现,vue内部通过fn.bind(this),把所以方法的this都进行了绑定。

模块化环境下,非render方法调用、通过on注册事件(无论组件内外)中的this指向的是undefined 【事件处理函数中】

模块化环境下,render方法中的this指向是当前instance

this指向解决方案(建议使用方案3)
  • 方案1:通过在render函数内调用去注册事件,结合箭头函数
js 复制代码
class App extends React.Component {
  state = {
    title: 'hello react'
  }
  buttonClick() {
    console.log(this.state.title)
  }
  render() {
    return (
      <div>
        <button onClick={() => {this.buttonClick()}}>
        点击按钮,查看this指向
        </button>
      </div>
    )
  }
}
  • 方案2:使用bind绑定当前this(不调用fn),不要用apply、call,因为它们会调用fn
js 复制代码
class App extends React.Component {
  state = {
    title: 'hello react'
  }
  buttonClick() {
    console.log(this.state.title)
  }
  render() {
    return (
      <div>
        <button onClick={this.buttonClick.bind(this)}>
        点击按钮,查看this指向
        </button>
      </div>
    )
  }
}
  • 方案3:声明方法的时候使用箭头函数,箭头函数没有自己的this,声明时就指向当前环境的this,就是instance
js 复制代码
class App extends React.Component {
  state = {
    title: 'hello react'
  }

  buttonClick = () => {
    console.log(this.state.title)
  }
  render() {
    return (
      <div>
        <button onClick={this.buttonClick}>
        点击按钮,查看this指向
        </button>
      </div>
    )
  }
}
相关推荐
nashane29 分钟前
HarmonyOS 6学习:Web组件同层渲染事件处理与智能长截图实现
前端·学习·harmonyos·harmonyos 5
大家的林语冰31 分钟前
Node 2026 发布,JS 三大新功能上线,最后一个奇偶版本
前端·javascript·node.js
三*一1 小时前
Mapbox GL JS 自研面要素整形工具开发实录
开发语言·javascript·arcgis·ecmascript
nashane1 小时前
HarmonyOS 6学习:Web组件同层渲染触摸事件与长截图拼接实战
前端·学习·harmonyos·harmonyos 5
我的世界洛天依1 小时前
胡桃讲编程|续篇!用高数 + JS ES262 硬核解构:求乐正绫的值
javascript
GISer_Jing2 小时前
浏览器 Agent 插件开发规格书 (SPEC)
前端·ai·前端框架·edge浏览器
别叫我->学废了->lol在线等2 小时前
评估总结模块(暂不做)
前端
清灵xmf2 小时前
CC Switch:解决 AI 编程工具配置
前端·人工智能·cc switch
IT_陈寒2 小时前
Redis缓存击穿把我坑惨了,原来这样解决才靠谱
前端·人工智能·后端
mfxcyh2 小时前
Vue3 右键菜单实现方案(基于 vue3-context-menu)
前端