本文转载自微信公众号「JS每日一题」,作者灰灰。转载本文请联系JS每日一题公众号。
React基于浏览器的事件机制自身实现了一套事件机制,包括事件注册、事件的合成、事件冒泡、事件派发等
在React中这套事件机制被称之为合成事件
合成事件(SyntheticEvent)
合成事件是 React模拟原生 DOM事件所有能力的一个事件对象,即浏览器原生事件的跨浏览器包装器
根据 W3C规范来定义合成事件,兼容所有浏览器,拥有与浏览器原生事件相同的接口,例如:
- const button =
如果想要获得原生DOM事件,可以通过e.nativeEvent属性获取
- const handleClick = (e) => console.log(e.nativeEvent);;
- const button =
从上面可以看到React事件和原生事件也非常的相似,但也有一定的区别:
- // 原生事件绑定方式
- // React 合成事件绑定方式
- const button =
- // 原生事件 事件处理函数写法
- // React 合成事件 事件处理函数写法
- const button =
虽然onclick看似绑定到DOM元素上,但实际并不会把事件代理函数直接绑定到真实的节点上,而是把所有的事件绑定到结构的最外层,使用一个统一的事件去监听
这个事件监听器上维持了一个映射来保存所有组件内部的事件监听和处理函数。当组件挂载或卸载时,只是在这个统一的事件监听器上插入或删除一些对象
当事件发生时,首先被这个统一的事件监听器处理,然后在映射里找到真正的事件处理函数并调用。这样做简化了事件处理和回收机制,效率也有很大提升
关于React合成事件与原生事件执行顺序,可以看看下面一个例子:
- import React from 'react';
- class App extends React.Component{
- constructor(props) {
- super(props);
- this.parentRef = React.createRef();
- this.childRef = React.createRef();
- }
- componentDidMount() {
- console.log("React componentDidMount!");
- this.parentRef.current?.addEventListener("click", () => {
- console.log("原生事件:父元素 DOM 事件监听!");
- });
- this.childRef.current?.addEventListener("click", () => {
- console.log("原生事件:子元素 DOM 事件监听!");
- });
- document.addEventListener("click", (e) => {
- console.log("原生事件:document DOM 事件监听!");
- });
- }
- parentClickFun = () => {
- console.log("React 事件:父元素事件监听!");
- };
- childClickFun = () => {
- console.log("React 事件:子元素事件监听!");
- };
- render() {
- return (
- 分析事件执行顺序
- );
- }
- }
- export default App;
输出顺序为:
- 原生事件:子元素 DOM 事件监听!
- 原生事件:父元素 DOM 事件监听!
- React 事件:子元素事件监听!
- React 事件:父元素事件监听!
- 原生事件:document DOM 事件监听!
可以得出以下结论:
对应过程如图所示:
所以想要阻止不同时间段的冒泡行为,对应使用不同的方法,对应如下:
- document.body.addEventListener('click', e => {
- if (e.target && e.target.matches('div.code')) {
- return;
- }
- this.setState({ active: false, }); });
- }
React事件机制总结如下:
参考文献
当前文章:面试官:说说对React事件机制的理解?
URL网址:http://www.csdahua.cn/qtweb/news47/319997.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网