发布于2021-05-30 11:45 阅读(944) 评论(0) 点赞(8) 收藏(0)
在正式讲解 React 事件之前,有必要了解一下 DOM 事件流,其包含三个流程:事件捕获阶段、处于目标阶段和事件冒泡阶段。
用于为特定元素绑定一个事件处理函数。addEventListener 有三个参数:
element.addEventListener(event, function, useCapture)
react的事件是合成事件((Synethic event),不是原生事件
如果DOM上绑定了过多的事件处理函数,整个页面响应以及内存占用可能都会受到影响。React为了避免这类DOM事件滥用,同时屏蔽底层不同浏览器之间的事件系统差异,实现了一个中间层——syntheticEvent。
syntheticEvent 是 react 基于 vitrual dom 的,react 事件处理器接收到一个 syntheticEvent 对象,syntheticEvent 和原生浏览器事件一样拥有同样的接口,也支持事件冒泡机制。可以通过 stopPropgation 和 preventDefault 中断。如果需要访问原生事件对象,可以使用 nativeEvent 属性。
注:「几乎」所有事件都代理到了 document,说明有例外,比如audio、video标签的一些媒体事件(如 onplay、onpause 等),是 document 所不具有,这些事件只能够在这些标签上进行事件进行代理,但依旧用统一的入口分发函数(dispatchEvent)进行绑定。
React 的事件注册过程主要做了两件事:document 上注册、存储事件回调。
document 上注册
在 React 组件挂载阶段,根据组件内的声明的事件类型(onclick、onchange 等),在 document 上注册事件(使用addEventListener),并指定统一的回调函数 dispatchEvent。换句话说,document 上不管注册的是什么事件,都具有统一的回调函数 dispatchEvent。也正是因为这一事件委托机制,具有同样的回调函数 dispatchEvent,所以对于同一种事件类型,不论在 document 上注册了几次,最终也只会保留一个有效实例,这能减少内存开销。
存储事件回调
React 为了在触发事件时可以查找到对应的回调去执行,会把组件内的所有事件统一地存放到一个对象中(listenerBank)。而存储方式如上图,首先会根据事件类型分类存储,例如 click 事件相关的统一存储在一个对象中,回调函数的存储采用键值对(key/value)的方式存储在对象中,key 是组件的唯一标识 id,value 对应的就是事件的回调函数。
事件分发也就是事件触发。React 的事件触发只会发生在 DOM 事件流的冒泡阶段,因为在 document 上注册时就默认是在冒泡阶段被触发执行。
其大致流程如下:
几乎所有的事件代理(delegate)到document,达到性能优化的目的。
对于每种类型的事件,拥有统一的分发函数dispatchEvent
事件对象(event)是合成对象(SyntheticEvent),不是原生的
写法不同
在原生事件中,事件名称使用小写,而 React 中使用驼峰命名。如果采用 JSX 的语法你需要传入一个函数作为事件处理函数,而不是一个字符串
// 原生事件
<button onclick="buttonClick()">
// React事件
<button onClick="buttonClick()">
阻止默认行为不同
在 HTML 中,阻止事件的默认行为使用 return false,而 React 中必须调用 preventDefault。
// 原生
<button onclick="console.log('123'); return false">
// React
function buttonClick(e) {
e.preventDefault()
}
机制不同
原生是直接将事件绑定到当前元素,React 组件上声明的事件没有绑定在 React 组件对应的原生 DOM 节点上。
React 中的事件机制则分为两个阶段:事件注册、事件分发。所有的事件都会注册到 document 上,当触发时,会采用事件冒泡的形式冒泡到document上面,然后React将事件封装给正式的函数处理运行和处理。
触发先后
由于 React 的事件委托机制,React 组件对应的原生 DOM 节点上的事件触发时机总是在 React 组件上的事件之前。
所以要注意,原生事件(阻止冒泡)会阻止合成事件的执行,合成事件(阻止冒泡)不会阻止原生事件的执行
参考链接
一文吃透 react 事件机制原理
【React深入】React事件机制
原文链接:https://blog.csdn.net/kelly0721/article/details/117259877
作者:听说你很拽
链接:http://www.qianduanheidong.com/blog/article/116062/9ed5994b594077ad9692/
来源:前端黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 前端黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-3
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!