当前位置:首页 > 科技  > 软件

React 合成事件和 JavaScript 事件有什么区别?

来源: 责编: 时间:2024-05-07 09:11:00 249观看
导读五一前帮一个同学做模拟面试的时候,聊到了 React 的合成事件和 JavaScript 原生事件的差异性问题。我发现很多 React 技术栈的同学对这一方面好像理解的并不清楚,所以今天咱们这篇文章主要就来说下这个问题。1.设计理念

五一前帮一个同学做模拟面试的时候,聊到了 React 的合成事件和 JavaScript 原生事件的差异性问题。我发现很多 React 技术栈的同学对这一方面好像理解的并不清楚,所以今天咱们这篇文章主要就来说下这个问题。CHE28资讯网——每日最新资讯28at.com

CHE28资讯网——每日最新资讯28at.com

1.设计理念

React合成事件 封装 了原生浏览器事件,提供了统一的API接口,使得开发者无论浏览器环境如何都可以用相同的方式处理事件。这种方法的主要目的是:确保跨浏览器的一致性并与 React 的声明式编程模型和生命周期集成。CHE28资讯网——每日最新资讯28at.com

JavaScript 中的事件处理程序 由浏览器直接提供,与特定的浏览器行为密切相关。不同的浏览器可能有不同的实现和支持级别。CHE28资讯网——每日最新资讯28at.com

2.浏览器兼容性

React 合成事件处理所有浏览器兼容性问题,为开发人员提供一个干净、一致的事件处理接口。CHE28资讯网——每日最新资讯28at.com

例如:它标准化了不同浏览器之间的事件行为,以事件冒泡和默认行为为例,咱们来看下它的实现:CHE28资讯网——每日最新资讯28at.com

// 构造器定义,接收事件配置、目标实例、本地事件和事件目标作为参数function SyntheticEvent(dispatchConfig, targetInst, nativeEvent, nativeEventTarget) {  this.dispatchConfig = dispatchConfig; // 存储事件的配置信息,例如事件类型  this._targetInst = targetInst; //存储触发事件的组件实例  this.nativeEvent = nativeEvent; // 存储本机浏览器事件对象  this.target = nativeEventTarget; // 存储事件的原生目标,即事件最初发生的多姆元素  this.currentTarget = null; // 处理事件的当前多姆元素将在事件处理期间设置}// SyneticEvents的原型对象,定义所有实例共享的方法SyntheticEvent.prototype = {  // Method to prevent the default event behavior  preventDefault: function() {    this.defaultPrevented = true; // 标志着事件的默认行为已被阻止    const event = this.nativeEvent; // 获取本地事件对象    if (!event) {      return; // 如果没有本地事件对象,则直接返回    }    // 如果本机事件对象支持preventAlert方法,请调用它以防止默认行为    if (event.preventDefault) {      event.preventDefault();    } else if (typeof event.returnValue !== 'undefined') { // 与IE8及以下版本兼容      event.returnValue = false; // 在较旧的IE浏览器中,使用returnValue= true来防止默认行为    }  },    // 阻止事件进一步传播的方法  stopPropagation: function() {    const event = this.nativeEvent; // 获取本地事件对象    if (!event) {      return; // 如果没有本地事件对象,则直接返回    }    // 如果本机事件对象支持stopPropagation方法,请调用它来停止事件冒泡    if (event.stopPropagation) {      event.stopPropagation();    } else if (typeof event.cancelBubble !== 'undefined') { // 与IE8及以下版本兼容      event.cancelBubble = true; // 在较旧的IE浏览器中,使用cancelBubble=true来停止事件冒泡    }  },  // ...};

3.性能优化

React 合成事件使用 事件池 来提高性能,即:重(chong)用事件对象。CHE28资讯网——每日最新资讯28at.com

这意味着:事件回调函数执行后,事件对象的所有属性都会被清除并回收以供重用,减少垃圾收集和内存使用的压力。CHE28资讯网——每日最新资讯28at.com

// 事件对象重用和回收的核心逻辑SyntheticEvent.prototype.destructor = function() {  this.target = null;  this.currentTarget = null;  this.dispatchConfig = null;  this._targetInst = null;  this.nativeEvent = null;  this.isDefaultPrevented = false;  this.isPropagationStopped = false;  // 清除所有属性....};// Event poolvar eventPool = [];// 从池中检索事件对象的函数SyntheticEvent.getPooled = function(dispatchConfig, targetInst, nativeEvent, nativeEventTarget) {  if (eventPool.length) {    var instance = eventPool.pop();    SyntheticEvent.call(instance, dispatchConfig, targetInst, nativeEvent, nativeEventTarget);    return instance;  }  return new SyntheticEvent(dispatchConfig, targetInst, nativeEvent, nativeEventTarget);};// 将事件对象返回到池的函数SyntheticEvent.release = function(event) {  event.destructor();  eventPool.push(event);};

而 JavaScript 事件每次触发时都会创建一个新的事件对象,这可能会增加内存使用量和垃圾收集的频率,特别是当事件频繁触发时(例如:滚动 或 输入)。”CHE28资讯网——每日最新资讯28at.com

4.使用模式

React 通过 JSX语法 允许我们直接在组件的元素上声明事件处理函数(合成事件)。CHE28资讯网——每日最新资讯28at.com

React 会自动处理添加和删除事件监听器,确保组件安装时添加监听器,卸载时删除监听器,从而避免内存泄漏。CHE28资讯网——每日最新资讯28at.com

export default function Button() {  function handleClick() {    console.log('click!');  }  return <button onClick={handleClick}>点我</button>;}

Javascript 事件需要手动调用 addEventListener 添加事件监听器,同样手动调用removeEventListener 删除事件监听器:CHE28资讯网——每日最新资讯28at.com

document.addEventListener('DOMContentLoaded', function() {  const button = document.querySelector('button');  button.addEventListener('click', function() {    console.log('click');  });});

5.总结

所以,React 的合成事件是 React 提供了一种高度抽象和集成的事件处理方式,并且可以更好地处理浏览器兼容性以及优化(卸载事件)等问题。它最终依然会被解析成原生事件。CHE28资讯网——每日最新资讯28at.com

而 JavaScript 原生事件就是浏览器所提供的标准 API,使用时需要更多的处理兼容性以及性能等边缘逻辑。CHE28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-86998-0.htmlReact 合成事件和 JavaScript 事件有什么区别?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 如何用C++实现简单的内存池

下一篇: Python 编程速查:迅速理解 next() 函数

标签:
  • 热门焦点
  • 对标苹果的灵动岛 华为带来实况窗功能

    继苹果的灵动岛之后,华为也在今天正式推出了“实况窗”功能。据今天鸿蒙OS 4.0的现场演示显示,华为的实况窗可以更高效的展现出实时通知,比如锁屏上就能看到外卖、打车、银行
  • 2023年Q2用户偏好榜:12+256G版本成新主流

    3月份的性能榜、性价比榜和好评榜之后,就要轮到2023年的第二季度偏好榜了,上半年的新机潮已经过去,最明显的肯定就是大内存和存储的机型了,另外部分中端机也取消了屏幕塑料支架
  • 6月安卓手机好评榜:魅族20 Pro蝉联冠军

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年6月1日至6月30日,仅限国内市场。第一名:魅族20 Pro好评率:95%5月份的时候魅族20 Pro就是
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 19个 JavaScript 单行代码技巧,让你看起来像个专业人士

    今天这篇文章跟大家分享18个JS单行代码,你只需花几分钟时间,即可帮助您了解一些您可能不知道的 JS 知识,如果您已经知道了,就当作复习一下,古人云,温故而知新嘛。现在,我们就开始今
  • 腾讯盖楼,字节拆墙

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之&ldquo;想重温暴刷深渊、30+技能搭配暴搓到爽的游戏体验吗?一起上晶核,即刻暴打!&rdquo;曾凭借直播腾讯旗下代理格斗游戏《DNF》一
  • 网红炒股不为了赚钱,那就是耍流氓!

    来源:首席商业评论6月26日高调宣布入市,网络名嘴大v胡锡进居然进军了股市。在一次财经媒体峰会上,几个财经圈媒体大佬就&ldquo;胡锡进炒股是否知道认真报道&rdquo;展开讨论。有
  • iQOO Neo8系列或定档5月23日:首发天玑9200+ 安卓跑分王者

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • 电博会上海尔智家模拟500平大平层,还原生活空间沉浸式体验

    电博会为了更好地让参展观众真正感受到智能家居的绝妙之处,海尔智家的程传岭先生同样介绍了展会上海尔智家的模拟500平大平层,还原生活空间沉浸式体验。程传
Top