js中事件的三个阶段(JavaScript中事件冒泡机制示例详析)
js中事件的三个阶段
JavaScript中事件冒泡机制示例详析什么是冒泡?
DOM事件流(event flow )存在三个阶段:事件捕获阶段、 处于目标阶段、 事件冒泡阶段。
事件捕获(event capturing):通俗的理解就是,当鼠标点击或者触发dom事件时,浏览器会从根节点开始由外到内进行事件传播,即点击了子元素,如果父元素通过事件捕获方式注册了对应的事件的话,会先触发父元素绑定的事件。
事件冒泡(dubbed bubbling):与事件捕获恰恰相反,事件冒泡顺序是由内到外进行事件传播,直到根节点。
dom标准事件流的触发的先后顺序为:先捕获再冒泡,即当触发dom事件时,会先进行事件捕获,捕获到事件源之后通过事件传播进行事件冒泡。不同的浏览器对此有着不同的实现,IE10及以下不支持捕获型事件,所以就少了一个事件捕获阶段,IE11、Chrome 、Firefox、Safari等浏览器则同时存在。
addEventListener()方法
这个方法设定一个事件监听器,当某一事件发生通过设定的参数执行操作。语法是:
addEventListener(event, function, useCapture)
参数 event 是必须的,表示监听的事件,例如 click, touchstart 等,就是之前不加前缀 on 的事件。
参数 function 也是必须的,表示事件触发后调用的函数,可以是外部定义函数,也可以是匿名函数。
参数 useCapture 是选填的,填true或者false,用于描述事件是冒泡还是捕获,true表示捕获,默认的false表示冒泡。
移除事件监听
如果要移除 addEventListener() 添加的事件监听,就要使用removeEventListener(),语法是:
removeEventListener(event, function)
参数与addEventListener()一致。
兼容性
IE 8及更早的版本,和Opera 7.0及更早的版本,不支持 addEventListener() 和 removeEventListener() 方法,他们使用的是一下方法代替:
添加事件:
attachEvent(event, function)
移除事件:
**detachEvent(event, function) **
可以用以下方法解决兼容性问题:
if (li1.addEventListener) { li1.addEventListener('click', function () { console.log("支持") }); } else if (li1.attachEvent) { li1.attachEvent('onclick', function () { console.log("不支持") }); }
冒泡和捕获的具体区别
HTML
<li id="li1"> <li id="li2"></li> </li>
JS
<script> var li1 = document.getElementById("li1"); var li2 = document.getElementById("li2"); li1.addEventListener('click',function(){ console.log("li1--捕获阶段") },true); li2.addEventListener('click',function(){ console.log("li2--捕获阶段") },true); li1.addEventListener('click',function(){ console.log("li1--冒泡阶段") }); li2.addEventListener('click',function(){ console.log("li2--冒泡阶段") }); </script>
输出结果(点击li2的时候执行的结果)
解决办法
function stopBubble(e) { if (e && e.stopPropagation) { e.stopPropagation(); //因此它支持W3C的stopPropagation()方法 } else { window.event.cancelBubble = true; //否则,我们需要使用IE的方式来取消事件冒泡 } }
总结
到此这篇关于JavaScript中事件冒泡机制的文章就介绍到这了,更多相关JavaScript事件冒泡内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- js中字符串拼接
- axios 请求前校验参数(js实现axios限制请求队列)
- js实现继承的五种(JavaScript继承的三种方法实例)
- js 原生事件代理(如何利用原生JS实现触摸滑动监听事件)
- jsforeach语句(JS面试题之forEach能否跳出循环详解)
- js使用递归解析(关于JavaScript递归经典案例题详析)
- js宏任务都有哪些(JavaScript 操作宏任务与微任务)
- js数组去重的十种方法(JavaScript常用数组去重实战源码)
- extjs Border边框布局
- python编写程序读写数据库(详解js文件通过python访问数据库方法)
- nginx安全配置提示(wdcp Linux面板nginx启用gzip后js未压缩解决方案)
- 微信小程序js 抽奖概率(小程序实现筛子抽奖)
- lombok 代码行数(Lombok实现方式JSR-269)
- qt和js相互调用(QT与javascript交互数据的实现)
- vuejs组件使用教程交流(Vue vee-validate插件的简单使用)
- JS中call和apply区别
- 相声转行影帝,被何晴抛弃,甩10年女友闪婚生子,刘威不靠谱情史(相声转行影帝被何晴抛弃)
- 岳云鹏不说相声,改行演员了 网友 快回来说相声(岳云鹏不说相声)
- 乔欣首演古装大女主,颜值演技双在线(乔欣首演古装大女主)
- 于正又推女性古装大剧 杨蓉乔欣演女配,两位女主成 重头戏(于正又推女性古装大剧)
- 乔欣古装女主戏获热度 作为女主,却没吃到红利(乔欣古装女主戏获热度)
- 爱情是什么(爱情是什么最经典的话)
热门推荐
- vuex数据持续化(Vuex数据持久化实现的思路与代码)
- php中命名空间常用吗(PHP命名空间定义与用法实例分析)
- python图片识别文字代码(python批量识别图片指定区域文字内容)
- pythonwhile语句的原理(谈谈Python中的while循环语句)
- python做出来的游戏按什么键运行(python pygame实现方向键控制小球)
- vue怎么配置到idea(idea编译器vue缩进报错问题场景分析)
- 让VS中Release模式下不生成pdb文件
- html和css制作导航条(使用Html+Css实现简易导航栏功能导航栏遇到鼠标切换背景颜色)
- mysql 查询json(MySQL处理JSON常见函数的使用)
- navicat不能连接到mysql报错2013(Navicat连接SQL Server数据:报错08001-命名管道提供程序的完美解决方法)