一、事件流

1.事件流

描述的是在页面中接受事件的顺序

2.事件冒泡

由最具体的元素接收,然后逐级向上传播至最不具体的元素的节点

(最具体 –> 最不具体)

3.事件捕获

最不具体的节点先接收事件,而最具体的节点应该是最后接收事件

(最不具体 –> 最具体)

2.事件处理

1.HTML事件处理

直接添加到HTML结构中

2.DOM0级事件处理

把一个函数赋值给一个事件处理程序属性

  1. <button id="btn">按钮</button>
  2. <script type="text/javascript">
  3. document.getElementById("btn").onclick = function () {
  4. alert("DOM0级事件处理1");//多个事件会被覆盖掉
  5. }
  6. document.getElementById("btn").onclick = function () {
  7. alert("DOM0级事件处理2");
  8. }
  9. </script>

3.DOM2级事件处理

addEventListener(“事件名”,”“事件处理函数”,“布尔值”)

当前版本,一般布尔值都不操作。

true:事件捕获

false:事件冒泡

removeEventListener();

  1. <button id="btn">按钮</button>
  2. <button id="btn2">DOM2级按钮</button>
  3. <script type="text/javascript">
  4. //document.getElementById("btn").onclick = function () {
  5. // alert("DOM0级事件处理1");//多个事件会被覆盖掉
  6. //}
  7. //document.getElementById("btn").onclick = function () {
  8. // alert("DOM0级事件处理2");
  9. //}
  10.  
  11. var btn2 = document.getElementById("btn2");
  12. btn2.addEventListener("click", function () {
  13. alert("DOM2级事件处理1");
  14. })
  15.  
  16. btn2.addEventListener("click", demo1);
  17. btn2.addEventListener("click", demo2);
  18.  
  19. function demo1() {
  20. alert("DOM2级事件处理2");
  21. }
  22.  
  23. function demo2() {
  24. alert("DOM2级事件处理3");
  25. }
  26. //移除
  27. //btn2.removeEventListener("click", demo2);
  28. </script>

4.IE事件处理程序

attachEvent

detachEvent

3.事件对象

事件对象event

1).type:获取事件类型

2).target:获取事件目标

  1. <div id="div1">
  2. <button id="btn1">按钮</button>
  3. </div>
  4. <script type="text/javascript">
  5. var btn1 = document.getElementById("btn1");
  6. var div1 = document.getElementById("div1");
  7. btn1.addEventListener("click", showType);
  8. div1.addEventListener("click", showDiv);
  9. function showType(event) {
  10. document.write(event.type+"<br>");
  11. document.write(event.target + "<br>");
  12. }
  13.  
  14. function showDiv(event) {
  15. alert("div");
  16. }
  17. </script>

3).stopPropagation():阻止事件冒泡

没有调用showDiv,冒泡被取消了。

  1. function showType(event) {
  2. document.write(event.type+"<br>");
  3. document.write(event.target + "<br>");
  4.  
  5. //组织事件冒泡
  6. event.stopPropagation();
  7. }

4).preventDefault():组织事件默认行为

(1)

  1. <a id="aid" href="http://www.baidu.com">百度</a>

js

  1. document.getElementById("aid").addEventListener("click", showaid);
  2. function showaid() {
  3. alert(1);
  4. }

(2)在showaid方法里面,添加

  1. e.stopPropagation();//阻止事件冒泡

(3)阻止默认行为

  1. function showaid(e) {
  2. alert(1);
  3. e.stopPropagation();//阻止事件冒泡
  4. e.preventDefault();//阻止默认行为(这里是跳转baidu)
  5. }

----->------>

javascript - 事件详解(阻止事件冒泡+阻止事件行为)的更多相关文章

  1. 【转载】C# 中的委托和事件(详解:简单易懂的讲解)

    本文转载自http://www.cnblogs.com/SkySoot/archive/2012/04/05/2433639.html C# 中的委托和事件(详解) C# 中的委托和事件 委托和事件在 ...

  2. JavaScript事件详解-jQuery的事件实现(三)

    正文 本文所涉及到的jQuery版本是3.1.1,可以在压缩包中找到event模块.该篇算是阅读笔记,jQuery代码太长.... Dean Edward的addEvent.js 相对于zepto的e ...

  3. JavaScript事件详解-Zepto的事件实现(二)【新增fastclick阅读笔记】

    正文 作者打字速度实在不咋地,源码部分就用图片代替了,都是截图,本文讲解的Zepto版本是1.2.0,在该版本中的event模块与1.1.6基本一致.此文的fastclick理解上在看过博客园各个大神 ...

  4. JavaScript事件详解-zepto的事件实现

    zepto的event 可以结合上一篇JavaScript事件详解-原生事件基础(一)综合考虑源码暂且不表,github里还有中文网站都能下到最新版的zepto.整个event模块不长,274行,我们 ...

  5. JAVASCRIPT事件详解-------原生事件基础....

    javaScirpt事件详解-原生事件基础(一)   事件 JavaScript与HTML之间的交互是通过事件实现的.事件,就是文档或浏览器窗口中发生的一些特定的交互瞬间,通过监听特定事件的发生,你能 ...

  6. react第五单元(事件系统-原生事件-react中的合成事件-详解事件的冒泡和捕获机制)

    第五单元(事件系统-原生事件-react中的合成事件-详解事件的冒泡和捕获机制) 课程目标 深入理解和掌握事件的冒泡及捕获机制 理解react中的合成事件的本质 在react组件中合理的使用原生事件 ...

  7. JavaScript中的鼠标滚轮事件详解

    JavaScript中的鼠标滚轮事件详解/*Firefox注册事件*/ ~~~Firefox: addEventListener('DOMMouseScroll', handler, false)if ...

  8. DOM——事件详解

    事件 事件:触发-响应机制 事件三要素 事件源:触发(被)事件的元素 事件名称: click 点击事件 事件处理程序:事件触发后要执行的代码(函数形式) 事件的基本使用  var box = docu ...

  9. 移动端开发touchstart,touchmove,touchend事件详解和项目

    移动端开发touchstart,touchmove,touchend事件详解和项目 最近在做移动端的开发,在一个“服务商管理”页面使用到了触摸事件"touchstart",&quo ...

  10. 第三天:JS事件详解-事件流

    学习来源: F:\新建文件夹 (2)\HTML5开发\HTML5开发\04.JavaScript基础\6.JavaScript事件详解 学习内容:  1)基础概念 2)举例说明: 代码如上,如果用事件 ...

随机推荐

  1. redis性能指标

    1.当内存使用达到设置的最大阀值时,需要选择一种key的回收策略,可在Redis.conf配置文件中修改“maxmemory-policy”属性值. 若是Redis数据集中的key都设置了过期时间,那 ...

  2. SpringMVC基础02——HelloWorld

    1.搭建环境 博主使用的环境是IDEA2017.3,首先我们需要创建一个maven项目父项目,创建一个project,选择maven,之后点击next 添写当前项目的坐标,之后点击next 填写项目名 ...

  3. Linux下创建仓库的软件包createrepo

    createrepo是linux下的创建仓库的软件包.create是创建的意思,repo是repository的缩写,是仓库的意思. yum(Yellow dog Updater,Modified)主 ...

  4. Chrome OS 更新新版本可让Linux访问USB连接的Android设备

    谷歌再次为Chrome OS带来了重大版本更新,使版本号达到了75.本次更新的一大亮点就是允许在Chrome OS上运行的Linux能够识别通过USB方式连接的Android设备,能够让用户使用Lin ...

  5. 青风nrf52832跑zephyr——点亮LED

    zephyr版本:1.10 硬件:采用青风nrf52832开发板 开发环境:虚拟机Ubuntu16.04编译+Windows7 64bit烧录   使用的是 zephyr-zephyr-v1.10.0 ...

  6. yum源遇到的问题

    1.在配置CentOS的本地yum源时,所遇到的问题,本地yum设置失败 步骤: vim /etc/yum.repos.d/local.repo  设置本地源  可能会遇到本地源问题,注意使用tab键 ...

  7. Lua语言基本语法~运算符

    Lua 变量 变量在使用前,必须在代码中进行声明,即创建该变量. 编译程序执行代码之前编译器需要知道如何给语句变量开辟存储区,用于存储变量的值. Lua 变量有三种类型:全局变量.局部变量.表中的域. ...

  8. 区块链——java实现

    简述 本文主要的内容试一次关于区块链的作业,本次作业中有很多地方和实际的区块链不符合,比如hash,本文实现的区块链只是用了区块本身的hash并没去区分,头部和数据部分.仅供参考学习. 介绍 内容有点 ...

  9. Spring MVC 文件上传简单示例(form、ajax方式 )

    1.Form Upload SpringMVC 中,文件的上传是通过 MultipartResolver 实现的,所以要实现上传,只要注册相应的 MultipartResolver 即可. Multi ...

  10. ASP.NET MVC5入门指南(1)*入门介绍

    以下指南说明了什么是ASP.NET MVC,并说明了如何入门. ASP.NET MVC 5入门 入门 添加控制器 添加视图 添加模型 创建连接字符串并使用SQL Server LocalDB 从控制器 ...