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

相关文章

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx

PostgreSQL 默认隔离级别的设置

《PostgreSQL默认隔离级别的设置》PostgreSQL的默认事务隔离级别是读已提交,这是其事务处理系统的基础行为模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一 默认隔离级别概述1.1 默认设置1.2 各版本一致性二 读已提交的特性2.1 行为特征2.2

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.

C++/类与对象/默认成员函数@构造函数的用法

《C++/类与对象/默认成员函数@构造函数的用法》:本文主要介绍C++/类与对象/默认成员函数@构造函数的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录名词概念默认成员函数构造函数概念函数特征显示构造函数隐式构造函数总结名词概念默认构造函数:不用传参就可以

C++类和对象之默认成员函数的使用解读

《C++类和对象之默认成员函数的使用解读》:本文主要介绍C++类和对象之默认成员函数的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、默认成员函数有哪些二、各默认成员函数详解默认构造函数析构函数拷贝构造函数拷贝赋值运算符三、默认成员函数的注意事项总结一

conda安装GPU版pytorch默认却是cpu版本

《conda安装GPU版pytorch默认却是cpu版本》本文主要介绍了遇到Conda安装PyTorchGPU版本却默认安装CPU的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录一、问题描述二、网上解决方案罗列【此节为反面方案罗列!!!】三、发现的根本原因[独家]3.1 p

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

VSCode中配置node.js的实现示例

《VSCode中配置node.js的实现示例》本文主要介绍了VSCode中配置node.js的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一.node.js下载安装教程二.配置npm三.配置环境变量四.VSCode配置五.心得一.no

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3