博客
关于我
事件冒泡、捕获?如何阻止
阅读量:388 次
发布时间:2019-03-05

本文共 1689 字,大约阅读时间需要 5 分钟。

事件冒泡

    
content
wraper
box

在这里插入图片描述

点击box后触发了wraper,content绑定的点击事件。这种由子元素向祖先元素触发的事件处理模型叫做事件冒泡。

事件冒泡应用:事件委托

利用事件冒泡,和事件源对象(e[非IE事件对象].target或event[IE事件对象].srcElement)进行处理。

事件捕获

事件捕获只需要把监听事件的第三个参数,false改为true。

box.addEventListener('click',function(e){           console.log('box')    },true)    wraper.addEventListener('click',function(e){           console.log('wraper')    },true)    content.addEventListener('click',function(e){           console.log('content')    },true)

在这里插入图片描述

发现控制台打印结果,反了过来,从祖先元素往子元素依次触发事件。IE不存在事件捕获。

事件冒泡和捕获优先级

// 事件捕获    box.addEventListener('click',function(e){           console.log('box捕获')    },true)    wraper.addEventListener('click',function(e){           console.log('wraper捕获')    },true)    content.addEventListener('click',function(e){           console.log('content捕获')    },true)    // 事件冒泡    box.addEventListener('click',function(e){           console.log('box冒泡')    },false)    wraper.addEventListener('click',function(e){           console.log('wraper冒泡')    },false)    content.addEventListener('click',function(e){           console.log('content冒泡')    },false)

在这里插入图片描述

由结果可知,先执行事件捕获,在执行事件冒泡。

阻止事件捕获,冒泡

使用e.stopPropagation()

IE使用event.cancelBubble = true(兼容所有IE) 或 event.stopPropagation() (IE9以下不兼容)

box.addEventListener('click',function(e){           e.stopPropagation()        console.log('box冒泡')    },false)    wraper.addEventListener('click',function(e){           console.log('wraper冒泡')    },false)    content.addEventListener('click',function(e){           console.log('content冒泡')    },false)

在这里插入图片描述

阻止事件捕获和事件冒泡都可以使用这个事件对象的stopPropagation方法阻止。

转载地址:http://nkhwz.baihongyu.com/

你可能感兴趣的文章
MySQL高频面试题的灵魂拷问
查看>>
MySQL(2)DDL详解
查看>>
Mysql,sql文件导入和导出
查看>>
MYSQL:int类型升级到bigint,对PHP开发语言影响
查看>>
Mysql:mysql 5.X 报错 ERROR 1193 (HY000): Unknown system variable ‘validate_password_length‘
查看>>
MySQL:MySQL执行一条SQL查询语句的执行过程
查看>>
Mysql:SQL性能分析
查看>>
mysql:SQL按时间查询方法总结
查看>>
MySQL:什么样的字段适合加索引?什么样的字段不适合加索引
查看>>
MySQL:判断逗号分隔的字符串中是否包含某个字符串
查看>>
MySQL:某个ip连接mysql失败次数过多,导致ip锁定
查看>>
Mysql:避免重复的插入数据方法汇总
查看>>
m_Orchestrate learning system---二十二、html代码如何变的容易
查看>>
n = 3 , while n , continue
查看>>
n 叉树后序遍历转换为链表问题的深入探讨
查看>>
N-Gram的基本原理
查看>>
nacos config
查看>>
Nacos 与 Eureka、Zookeeper 和 Consul 等其他注册中心的区别
查看>>
Nacos2.X 配置中心源码分析:客户端如何拉取配置、服务端配置发布客户端监听机制
查看>>
NacosClient客户端搭建,微服务注册进nacos
查看>>