1、首先react有自己的事件系统,也是遵循w3c的,这个事件系统的名称叫做合成事件。而自定义事件系统的动机只要包含一下几个方面:
- 抹平不同浏览器之间的兼容性差异。最主要的动机。
- 件合成既可以处理兼容性问题
- 提供一个抽象的跨平台事件机制
- 可以做更多优化
- 可以干预事件的分发
2、当给组件(元素)绑定onClick事件之后
- react会对事件先进行注册,将事件统一注册到document上
- 根据组件唯一的标识key来对事件函数进行存储
3、统一的指定dispatchEvent回调函数
4、 储存事件回调
react会将click这个事件统一存到一个对象中,回调函数的存储采用键值对(key/value)的方式存储在对象中,key 是组件的唯一标识 id,value 对应的就是事件的回调函数,通过组件的key就能回调到相应的函数了