当前位置: 首页 > news >正文

React中的合成事件解释和理解

什么是合成事件(Synthetic event)?它和原生事件有什么区别?

解题思路:解释合成事件,然后对比原生事件,然后再说他的优势

1.一致性
在 react里面,这个合成事件是非常重要的,因为它就是为了解决浏览器之间与事件模型的一些差异,像一些不同的浏览器,对事件的绑定与解绑机制都是会有区别的,如果说react不去抽象这样一层,到了别的平台他去实现事件的响应和处理都会出现问题的,于是他在原生事件和我们编写的代码中间给他来了一层中间层,这一层也就是合成事件,说白了就是避免浏览器差异引起的问题,为了保持一致性

2.事件池化
react在合成事件对象的实现中采用了事件池化策略,这意味着当事件处理完之后,react会将事件对象重新放回到池中,而不是保留每个事件的实例,从而减少消耗内存,事件池化的实现意味着事件对象只能在回调函数中访问,而回调执行后,属性会被清空

3.统一的接口
合成事件封装了标准的原生事件接口,并提供了一致的API来访问事件的属性,如event.target,event.preventDefault()和event.stopPrepageation();

区别:

1.浏览器的兼容性,合成事件更好,因为原生的事件对于各种浏览器处理,订阅机制不一样.

2.react的合成事件会通过事件池的来优化订阅的函数 ,比如useMemo,useCallBack这些函数都可以去缓存函数,和事件池一样的机制

3.在性能优化方面,原生事件每次都会创建一个事件对象,对性能影响非常大,但合成事件,它是通过事件池来解决的,从而减少了内存的消耗

http://www.lryc.cn/news/602143.html

相关文章:

  • 架构实战——互联网架构模板(“开发层”和“服务层”技术)
  • DevOps时代的知识治理革命:Wiki如何成为研发效能的新引擎
  • 并发安全之锁机制一
  • 小架构step系列28:自定义校验注解
  • “太赫兹”
  • KubeSphere理论及实战
  • Error reading config file (/home/ansible.cfg): ‘ACTION_WARNINGS(default) = True
  • 什么是3DVR?VR技术有哪些应用场景?
  • 关于sql面试积累
  • 红绿灯纵向距离的评估
  • 【查漏补缺】机器学习典型算法
  • 【Java Web实战】从零到一打造企业级网上购书网站系统 | 完整开发实录(终)
  • 应用加速游戏盾的安全作用
  • Java BigDecimal详解:小数精确计算、使用方法与常见问题解决方案
  • 【数据库】使用Sql Server将分组后指定字段的行数据转为一个字段显示,并且以逗号隔开每个值,收藏不迷路
  • GaussDB 开发基本规范
  • 22 BTLO 蓝队靶场 Countdown 解题记录
  • 如何利用机器学习分析筛选生物标记物
  • 微信小程序——早餐小程序
  • TMS320F28335PGFA TI德州仪器:32位浮点内核+CLA协处理器DSP,工业控制性能极限!
  • 【Linux指南】Linux粘滞位详解:解决共享目录文件删除安全隐患
  • CJ02、CJ20N下达项目报错用户状态 初始 是活动的,怎么解决?
  • 模型压缩的一些整理
  • 异步通讯组件MQ
  • 【Linux系统】Ext2文件系统 | 软硬链接
  • 医疗人工智能高质量数据集和语料库建设路径探析
  • HOT100——链表篇Leetcode206. 反转链表
  • qt 心跳包
  • Java面试宝典:Spring Boot
  • 解决MySQL 1055错误:ONLY_FULL_GROUP_BY问题详解(MySQL 8.0版)