js 绑定事件,冒泡事件,默认事件

2024-09-03 19:08
文章标签 js 绑定 事件 默认 冒泡

本文主要是介绍js 绑定事件,冒泡事件,默认事件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

addEventListener

定义:addEventListener() 方法用于向指定元素添加事件句柄。

element.addEventListener(event, function, useCapture)
/**useCapture:1.可选。布尔值,指定事件是否在捕获或冒泡阶段执行。2.true - 事件句柄在捕获阶段执行3.false- 默认。事件句柄在冒泡阶段执行
*/// eg:
<input type="button" id="c3" value="点击" onclick="alert(3)">
document.getElementById('c3').addEventListener('click',function(e){e.stopPropagation()},false);

默认事件: event.preventDefault()

<a href="http://www.baidu.com" target="_black">百度</a>

1.在没有阻止默认事件前,点击后直接跳转百度。
2.阻止默认事件后,a标签点击无效:

var aDom= document.getElementByTagName("a");
aDom.addEventListener("click", function(e){e.preventDefault()}, false);

冒泡事件:

1.定义

事件按照从最特定的事件目标到最不特定事件目标顺序逐一触发

2.阻止冒泡事件

  • event.preventDefault( ); 阻止通过 addEventListener( ) 添加的事件的默认事件
element.addEventListener("click", function(e){var event = e || window.event;event.preventDefault( ); //阻止默认事件
},false);
  • return false; 阻止独享属性(通过on这种方式)绑定的事件的默认事件
element.onclick = function() {return false; //通过返回false值阻止默认事件行为
};
  • event.returnValue = false; 阻止通过 attachEvent( ) 添加的事件的默认事件
element.attachEvent("onclick", function(e){var event = e || window.event;event.returnValue = false; //阻止默认事件
},false);

3.举例

看如下html源码,每一个元素都添加了点击事件,在没有任何处理之前,点击 button 按钮,从按钮id C3 > c2 > c1,逐级网上出发,相应输出:3,2,1,这就是冒泡事件现象

<!-- 源码2.1 -->
<div id="c1" onclick="alert(1)"><div id="c2" onlick="alert(2)"><input id="c3" type="button" value="点击" onclick="alert(3)"></div>
</div>

点击button时:
1.没添加任何处理之前,先后会弹出 3,2,1
2.添加阻止冒泡事件处理后,只会弹出 3;

// 添加阻止冒泡事件
document.getElementById('c3').addEventListener('click',function(e){e.stopPropagation()},true);

扩展:捕获事件和冒泡事件,更好是一个相反的过程;
定义:从不精确的对象到最精准的对象。这种事件也称作自顶向下事件模型,因为它是从DOM层次的顶端开始向下延伸的。
注意:IE浏览器不支持这种类型事件,我们只需要了解即可。

绑定元素事件,兼容性写法:

// 事件绑定
function addEvent(element, eType, handle, bol) {if(element.addEventListener){           //如果支持addEventListenerelement.addEventListener(eType, handle, bol);}else if(element.attachEvent){          //如果支持attachEventelement.attachEvent("on"+eType, handle);}else{                                  //否则使用兼容的onclick绑定element["on"+eType] = handle;}
}// 事件解绑
function removeEvent(element, eType, handle, bol) {if(element.addEventListener){element.removeEventListener(eType, handle, bol);}else if(element.attachEvent){element.detachEvent("on"+eType, handle);}else{element["on"+eType] = null;}
}

参考:http://www.cnblogs.com/zhangmingze/p/4864367.html

这篇关于js 绑定事件,冒泡事件,默认事件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1133794

相关文章

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

PyCharm如何设置新建文件默认为LF换行符

《PyCharm如何设置新建文件默认为LF换行符》:本文主要介绍PyCharm如何设置新建文件默认为LF换行符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录PyCharm设置新建文件默认为LF换行符设置换行符修改换行符总结PyCharm设置新建文件默认为LF

基于@RequestParam注解之Spring MVC参数绑定的利器

《基于@RequestParam注解之SpringMVC参数绑定的利器》:本文主要介绍基于@RequestParam注解之SpringMVC参数绑定的利器,具有很好的参考价值,希望对大家有所帮助... 目录@RequestParam注解:Spring MVC参数绑定的利器什么是@RequestParam?@

spring @EventListener 事件与监听的示例详解

《spring@EventListener事件与监听的示例详解》本文介绍了自定义Spring事件和监听器的方法,包括如何发布事件、监听事件以及如何处理异步事件,通过示例代码和日志,展示了事件的顺序... 目录1、自定义Application Event2、自定义监听3、测试4、源代码5、其他5.1 顺序执行

Node.js net模块的使用示例

《Node.jsnet模块的使用示例》本文主要介绍了Node.jsnet模块的使用示例,net模块支持TCP通信,处理TCP连接和数据传输,具有一定的参考价值,感兴趣的可以了解一下... 目录简介引入 net 模块核心概念TCP (传输控制协议)Socket服务器TCP 服务器创建基本服务器服务器配置选项服

mac安装nvm(node.js)多版本管理实践步骤

《mac安装nvm(node.js)多版本管理实践步骤》:本文主要介绍mac安装nvm(node.js)多版本管理的相关资料,NVM是一个用于管理多个Node.js版本的命令行工具,它允许开发者在... 目录NVM功能简介MAC安装实践一、下载nvm二、安装nvm三、安装node.js总结NVM功能简介N

MySQL9.0默认路径安装下重置root密码

《MySQL9.0默认路径安装下重置root密码》本文主要介绍了MySQL9.0默认路径安装下重置root密码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录问题描述环境描述解决方法正常模式下修改密码报错原因问题描述mysqlChina编程采用默认安装路径,

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点: