JavaScript的事件流2

简介: JavaScript的事件流2

2. 取消冒泡事件

这里试着取消box的冒泡事件。 当我们点击box区域时,应该仅仅返回“2. box 冒泡”的打印结果。

box.addEventListener('click',function(e) {
    console.log('2. box 冒泡');
    e = e || window.event;
    var target = e.target || e.srcElement; // 后一种为兼容IE的写法
    console.log(target);
    // 冒泡事件取消
    if(e.stopPropagation) { // W3C标准
        e.stopPropagation();
    }else { 
        e.cancelBubble = true; // IE & Chrome支持
    }
}, false);

2.1 点击box区域

1688211220897.png

结果显示,取消box的冒泡事件成功。

七、默认事件

我们知道在点击某些控件或者元素时,会出现刷新页面的效果,这些事件就是默认事件。 典型的默认事件有:

  1. 表单提交
  2. a标签的跳转
  3. 点击右键弹出菜单

八、取消默认事件

在我们开发的过程中,我们往往不需要这些触发的默认事件。那么如何取消呢?

1. 方式

  1. onType: return false;
  2. W3C: event.preventDefault();
  3. IE: event.returnValue = false;

2. 案例

这里以取消右键菜单的默认事件为例。

1. 第一种方式

document.oncontextmenu = function() {
    console.log('right click');
    return false;
}

2. 第二种方式

document.addEventListener('contextmenu', function(e) {
    console.log('addEventListener contextmenu');
    e = e || window.event;
    if(e.preventDefault) {
        e.preventDefault();
    }else {
    e.returnValue = false;
    }
}, false);

九、本节思维导图

1688211253956.png

1688211265797.png

目录
相关文章
|
11月前
|
JavaScript 前端开发 UED
JS DOM 事件流与事件冒泡
【10月更文挑战第16天】理解 DOM 事件流和事件冒泡是掌握 JavaScript 事件处理的关键。通过合理利用事件冒泡,可以实现更高效、灵活的事件处理机制,提升用户体验和开发效率。在实际开发中,要根据具体情况灵活运用这些概念,以达到最佳的效果。
187 42
|
JavaScript 前端开发
JavaScript 事件流
JavaScript 事件流
83 1
|
JavaScript
js 事件流、事件冒泡、事件捕获、阻止事件的传播
js 事件流、事件冒泡、事件捕获、阻止事件的传播
201 1
|
Web App开发 JavaScript 前端开发
JavaScript的事件流1
JavaScript的事件流
165 0
|
JavaScript 前端开发
|
JavaScript 前端开发 API
探索JavaScript事件流:DOM中的神奇旅程
JavaScript中的事件流是一种机制,用于描述和处理事件在DOM树中的传播过程。了解事件流的属性和工作原理对于编写高效的事件处理代码和实现复杂的交互功能至关重要。本文将详细介绍JavaScript事件流的发展流程、属性以及应用场景,并提供一些代码示例和引用资料,帮助读者深入理解并应用这一重要的前端技术。
|
JavaScript 前端开发
JavaScript 事件流
JavaScript 事件流
77 0
|
前端开发 JavaScript 开发者
带你读《现代Javascript高级教程》八、JavaScript事件流:深入理解事件处理和传播机制(1)
带你读《现代Javascript高级教程》八、JavaScript事件流:深入理解事件处理和传播机制(1)
211 0
|
前端开发 JavaScript
带你读《现代Javascript高级教程》八、JavaScript事件流:深入理解事件处理和传播机制(2)
带你读《现代Javascript高级教程》八、JavaScript事件流:深入理解事件处理和传播机制(2)
132 0
|
JavaScript 前端开发
带你读《现代Javascript高级教程》八、JavaScript事件流:深入理解事件处理和传播机制(3)
带你读《现代Javascript高级教程》八、JavaScript事件流:深入理解事件处理和传播机制(3)
142 0