jacascript 事件对象event
前言:这是笔者学习之后自己的理解与整理。如果有错误或者疑问的地方,请大家指正,我会持续更新!
在触发DOM上的某个事件时,会产生一个事件对象 event,这个对象中包含着所有与事件有关的信息。所有浏览器都支持 event 对象,但有兼容性问题。
获取事件对象
一般地,event 对象是事件程序的第一个参数。IE8及以下浏览器不支持;
另一种方法是直接使用 event 变量,firefox 浏览器不支持;
获取事件对象的常见兼容写法:
<div id="box" style="height:200px;width:200px;background:pink;"></div>
<script>
var oBox = document.getElementById('box');
oBox.onclick = function(ev){
ev = ev || event;//获取事件对象的常见兼容写法
box.innerHTML = ev;
}
</script>
事件类型
事件有很多类型,事件对象中的 type 属性表示被触发的事件类型;
<div id="box" style="height:200px;width:200px;background:pink;"></div>
<script>
var oBox = document.getElementById('box');
oBox.onclick = function(ev){
ev = ev || event;//获取事件对象的常见兼容写法
box.innerHTML = ev.type;//事件对象中的type属性表示被触发的事件类型
}
</script>
事件目标
关于事件目标,共有 currentTarget、target 和 srcElement 这三个属性;
currentTarget 属性返回事件当前所在的节点,即正在执行的监听函数所绑定的那个节点;IE8及以下浏览器不支持 ;
currentTarget 与事件中的 this 指向相同;
target 属性返回事件的实际目标节点;IE8及以下浏览器不支持;
srcElement 属性与 target 属性功能一致,返回事件的实际目标节点;firefox 浏览器不支持;
<style type="text/css">
#box{height:200px;width:200px;background-color:pink;}
#child{height: 100px;width: 100px;background-color: green;}
</style>
<div id="box">
<div id="child"></div>
</div>
<script>
var oBox = document.getElementById('box');
var oChild = document.getElementById('child');
oBox.onclick = function(ev){
ev = ev || event;
//currentTarget属性返回事件当前所在的节点,即正在执行的监听函数所绑定的那个节点
console.log(ev.currentTarget);//<div id="box">...</div> //currentTarget与事件中的this指向相同
console.log(ev.currentTarget === this);//true //target属性返回事件的实际目标节点,IE8及以下浏览器不支持
//srcElement 属性与 target 属性功能一致,返回事件的实际目标节点;firefox 浏览器不支持;
//兼容性写法:
var target = ev.target || ev.srcElement;
console.log(target);//<div id="child"></div>
}
</script>
事件代理
由于事件会在冒泡阶段向上传播到父节点,因此可以把子节点的监听函数定义在父节点上,由父节点的监听函数统一处理多个子元素的事件。这种方法叫做事件的代理(delegation),也叫事件委托;
事件代理应用事件目标的 target 和 srcElement 属性完成。利用事件代理,可以提高性能及降低代码复杂度;
<style>
#box{background-color: pink;}
.in{height: 30px;}
</style>
<ul id="box">
<li class="in">1</li>
<li class="in">2</li>
<li class="in">3</li>
<li class="in">4</li>
<li class="in">5</li>
</ul>
<script>
var oBox = document.getElementById('box');
oBox.onmouseover = function(ev){
ev = ev || event;
var target = ev.target || ev.srcElement;
target.style.backgroundColor = 'lightblue';
}
oBox.onmouseout = function(ev){
ev = ev || event;
var target = ev.target || ev.srcElement;
target.style.backgroundColor = 'pink';
}
</script>
事件冒泡
事件冒泡是事件流的第三个阶段,通过事件冒泡可以在这个阶段对事件做出响应;
关于冒泡,事件对象中包含 bubbles、cancelBubble、stopPropagation() 和 stopImmediatePropagation() 这四个相关的属性和方法;
bubbles 属性返回一个布尔值,表示当前事件是否会冒泡。该属性为只读属性。发生在文档元素上的大部分事件都会冒泡,但 focus、blur 和 scroll 事件不会冒泡。所以,除了这三个事件 bubbles 属性返回 false 外,其他事件该属性都为true;
stopPropagation() 方法表示取消事件的进一步捕获或冒泡,但无法阻止同一事件的其他监听函数被调用,无返回值。IE8及以下浏览器不支持;
stopImmediatePropagation() 方法不仅可以取消事件的进一步捕获或冒泡,而且可以阻止同一个事件的其他监听函数被调用,无返回值。IE8及以下浏览器不支持;
<div id="box" style="height: 200px;width: 200px; background-color: pink;"></div>
<script>
var oBox = document.getElementById('box');
oBox.onclick = function(ev){
ev = ev || event;
//bubbles 属性返回一个布尔值,表示当前事件是否会冒泡
console.log(ev.bubbles);//true
}
oBox.addEventListener('click',function(ev){
ev = ev || event;
//stopPropagation() 方法表示取消事件的进一步捕获或冒泡,
ev.stopPropagation();
oBox.innerHTML +='stopPropagation() 方法表示取消事件的进一步捕获或冒泡<br/>';
}) //stopPropagation() 方法表示取消事件的进一步捕获或冒泡,但无法阻止同一事件的其他监听函数被调用
oBox.addEventListener('click',function(ev){
ev = ev || event;
oBox.innerHTML += '但无法阻止同一事件的其他监听函数被调用';
}) document.body.onclick = function(ev){
oBox.innerHTML += '冒泡已被阻止';
}
</script>
cancelBubble 属性只能用于阻止冒泡,无法阻止捕获阶段。该值可读写,默认值是false。当设置为 true 时,cancelBubble 可以取消事件冒泡;该属性全浏览器支持,但并不是标准写法;
<script type="text/javascript">
var handler = function(ev){
ev = ev || event;
if(ev.stopPropagation){
ev.stopPropagation();
}else{
ev.cancelBubble = true;
}
}
</script>
事件流
eventPhase 属性返回一个整数值,表示事件目前所处的事件流阶段,IE8及以下浏览器不支持;
0表示事件没有发生,1表示捕获阶段,2表示目标阶段,3表示冒泡阶段;
取消默认行为
关于取消默认行为的属性包括 cancelable、defaultPrevented、preventDefault() 和 returnValue ;
cancelable 属性返回一个布尔值,表示事件是否可以取消。该属性为只读属性。返回true时,表示可以取消。否则,表示不可取消;IE8及以下浏览器不支持;
defaultPrevented 属性表示默认行为是否被阻止,返回 true 时表示被阻止,返回 false 时,表示未被阻止;IE8及以下浏览器不支持;
<div id="box" style="height: 200px;width: 200px; background-color: pink;"></div>
<script>
var oBox = document.getElementById('box');
oBox.onclick = function(ev){
ev = ev || event;
//cancelable 属性返回一个布尔值,表示事件是否可以取消
console.log(ev.cancelable );//true
//defaultPrevented 属性表示默认行为是否被阻止
console.log(ev.defaultPrevented );//false
}
</script>
preventDefault() 方法取消浏览器对当前事件的默认行为,无返回值;IE8及以下浏览器不支持;
<div id="box" style="height: 200px;width: 200px; background-color: pink;"></div>
<script>
var oBox = document.getElementById('box');
oBox.onclick = function(ev){
ev = ev || event;
//cancelable 属性返回一个布尔值,表示事件是否可以取消
console.log(ev.cancelable );//true
//defaultPrevented 属性表示默认行为是否被阻止
console.log(ev.defaultPrevented );//false //preventDefault() 方法取消浏览器对当前事件的默认行为
ev.preventDefault();
//defaultPrevented 属性表示默认行为是否被阻止
console.log(ev.defaultPrevented );//true
}
</script>
returnValue 属性可读写,默认值是true,但将其设置为 false 就可以取消事件的默认行为,与 preventDefault() 方法的作用相同;firefox 和 IE9及以上浏览器不支持;
兼容性写法:
<script type="text/javascript">
var handler = function(e){
ev = ev || event;
if(ev.preventDefault){
ev.preventDefault();
}else{
ev.returnValue = false;
}
}
</script>
jacascript 事件对象event的更多相关文章
- 重新审视事件对象event
前言:之前在学习事件对象event时,一是一直在chrome浏览器(作为主运行环境)下运行调试自个儿程序,二是可能当时对事件对象理解不透彻才导致现在对事件对象的用法陷入了一个大坑,遂以此篇博客记之. ...
- 谈谈事件对象-event
JavaScript 中的事件对象(event) 当我们每次触发一种事件(如点击事件),我们会在回调函数中传入事件对象event.今天就来来谈谈. 1.当我们想判断当前事件是我们想要的事件类型时,可以 ...
- JavaScript:事件对象Event和冒泡
本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. 绑定事件的两种方式 我们在上一篇文章中已经讲过事件的概念.这里讲一下注册 ...
- javaScript中的事件对象event
事件对象event,每当一个事件被触发的时候,就会随之产恒一个事件对象event,该对象中主要包括了关于该事件的基本属性,事件类型type(click.dbclick等值).目标元素target(我的 ...
- Javascript和jquery事件--事件对象event
1. 事件对象event 对于event,js的解释是Event 对象代表事件的状态,比如事件在其中发生的元素.键盘按键的状态.鼠标的位置.鼠标按钮的状态.而jq的解释是事件处理(事件对象.目标元素 ...
- js进阶课程 12-9 jquery的事件对象event的方法有哪些?
js进阶课程 12-9 jquery的事件对象event的方法有哪些? 一.总结 一句话总结:三组六个,阻止默认事件一组,阻止冒泡一组,阻止冒泡和剩余事件一组. 1.事件的默认动作指什么? 比如点a标 ...
- JS-特效 ~ 03. 楼层跳跃、事件对象event的获取与使用、event的主要内容、screenX、pageX、clientX的区别、放大镜、模拟滚动条
楼层跳跃 100%子盒子会继承父盒子的宽高.父盒子继承body宽高.Body继承html的宽高. 盒子属性:auto:适应盒子自身的宽度或者高度.(对自己负责) 盒子属性:100%:适应盒子父盒子的宽 ...
- js 事件对象event
在触发DOM上的某个事件时,会产生一个事件对象event.这个对象中包含着所有与事件有关的信息.包括导致事件的元素,事件的类型以及其他与特定事件相关的信息. <body> <a hr ...
- javaScript中的事件对象event是怎样
事件对象event,每当一个事件被触发的时候,就会随之产恒一个事件对象event,该对象中主要包含了关于该事件的基本属性,事件类型type(click.dbclick等值).目标元素target(我的 ...
随机推荐
- js对象系列【一】深层理解对象与原型
我们先从盘古开天辟地时捋一捋对象: 从宏观内容来讲,javascript是一个属性的集合,包括值,函数,而整个集合也可以类比为一个对象. js = { a的变量名: a的值, ... 函数b: fun ...
- 笔记:Jersey REST 传输格式-XML
XML类型是使用最广泛的数据类型,Jersey 对XML类型的数据处理,支持Java领域的两大标准,即JAXP(Java API for XML Processing,JSR-206)和JAXB(Ja ...
- 【Python】 更棒的Excel操作模块xlwings
[xlwings] 说到Python操作Excel,有好多模块都可以支持这个工作.比如最底层的win32模块不仅可以操作Excel,还可以操作其他一众windows的软件. 其他的比较熟悉的有xlrd ...
- 目前微服务/REST的最佳技术栈
服务端 日期 编程语言 Web Framework DbAccess/ORM 数据库 2017-09-07 Node.js 8.4 Koa 2.3 sequelize 4.8 MySQL 2017-0 ...
- Lucene 4.4.0中常用的几个分词器
一.WhitespaceAnalyzer 以空格作为切词标准,不对语汇单元进行其他规范化处理.很明显这个实用英文,单词之间用空格. 二.SimpleAnalyzer 以非字母符来分割文本信息,并将语汇 ...
- grep -vFf 比较2个文件差异
grep -vFf 1.txt 2.txt 打印出2.txt中与1.txt有差异的数据. #cat .txt 192.168.0.1 192.168.0.2 192.168.0.3 #cat .t ...
- 2017-2018-1 1623 bug终结者 冲刺005
bug终结者 冲刺005 by 20162323 周楠 今日任务:理清游戏运行逻辑,GameView类为游戏核心代码 简要介绍 游戏中整个地图都是由数组组成 1.整个地图为16×16格,主要元素有墙. ...
- 201621123025《Java程序设计》第1周学习总结
201621123025<Jave程序设计>第一周学习总结 1.本章学习总结 对于java这门课程,如果不会编码那么会很难学会如何去使用它,而在大一的一二学期的专业课--C语言和数据结构我 ...
- C语言--第四周作业
一.题目7-1 计算分段函数[1] 1.代码 #include <stdio.h> int main () { float x,result; scanf("%f",& ...
- QTableView
QTableView常用于实现数据的表格显示.下面我们如何按步骤实现学生信息表格: 一 添加表头 //准备数据模型 QStandardItemModel *student_model = ne ...