本文出自:春哥个人博客:http://www.liyuechun.org
作者:©黎跃春-追时间的人
简介:JavaScript30 是 Wes Bos 推出的一个 30 天挑战。项目免费提供了 30 个视频教程、30 个挑战的起始文档和 30 个挑战解决方案源代码。目的是帮助人们用纯 JavaScript 来写东西,不借助框架和库,也不使用编译器和引用。现在你看到的是这系列指南的第 25 篇。完整中文版指南及视频教程在 从零到壹全栈部落。
效果图
第25天的训练是学习DOM的事件机制,主要包括事件捕获,事件冒泡,单次执行事件。
源代码
<script>
let divs = document.querySelectorAll('div');
let one = document.querySelector('.one');
let two = document.querySelector('.two');
let three = document.querySelector('.three');
divs.forEach(div => div.addEventListener('click', logText, {
once: true,
capture: false
}));
// one.addEventListener('click', logText1, {
// // capture: true
// });
// two.addEventListener('click', logText2, {
// // capture: true
// });
// three.addEventListener('click', logText3, {
// capture: true
// });
function logText(e) {
console.log(this.classList.value);
// e.stopPropagation();
}
function logText1(e) {
console.log(this.classList.value);
// e.stopPropagation();
}
function logText2(e) {
console.log(this.classList.value);
// e.stopPropagation();
}
function logText3(e) {
console.log(this.classList.value);
e.stopPropagation();
}
</script>
同时也看一下HTML的文档结构,对于事件机制的理解也很重要:
<div class="one">
<div class="two">
<div class="three">
</div>
</div>
</div>
EventTarget.addEventListener('eventName',callback,option)
:元素的事件注册方法,接收三个参数,第一个参数为事件的名称(点击click
、双击dbclick
、改变change
等),第二个参数是该事件的回调函数,也称为监听器,第三个参数为事件注册的选项对象,通常会包含两个配置项(是否事件捕获capture
以及单次执行once
事件,它们两个的默认值都是false
)。- 当我们点击
class="three"
的div
的时候,我们也相当于同时点击了class="two"
和class="one"
。 e.stopPropagation();
是否停止冒泡,如果调用了这个方法,就不会触发父组建的方法。