前言:这是笔者学习之后自己的理解与整理。如果有错误或者疑问的地方,请大家指正,我会持续更新!

  在触发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的更多相关文章

  1. 重新审视事件对象event

    前言:之前在学习事件对象event时,一是一直在chrome浏览器(作为主运行环境)下运行调试自个儿程序,二是可能当时对事件对象理解不透彻才导致现在对事件对象的用法陷入了一个大坑,遂以此篇博客记之. ...

  2. 谈谈事件对象-event

    JavaScript 中的事件对象(event) 当我们每次触发一种事件(如点击事件),我们会在回调函数中传入事件对象event.今天就来来谈谈. 1.当我们想判断当前事件是我们想要的事件类型时,可以 ...

  3. JavaScript:事件对象Event和冒泡

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. 绑定事件的两种方式 我们在上一篇文章中已经讲过事件的概念.这里讲一下注册 ...

  4. javaScript中的事件对象event

    事件对象event,每当一个事件被触发的时候,就会随之产恒一个事件对象event,该对象中主要包括了关于该事件的基本属性,事件类型type(click.dbclick等值).目标元素target(我的 ...

  5. Javascript和jquery事件--事件对象event

    1.  事件对象event 对于event,js的解释是Event 对象代表事件的状态,比如事件在其中发生的元素.键盘按键的状态.鼠标的位置.鼠标按钮的状态.而jq的解释是事件处理(事件对象.目标元素 ...

  6. js进阶课程 12-9 jquery的事件对象event的方法有哪些?

    js进阶课程 12-9 jquery的事件对象event的方法有哪些? 一.总结 一句话总结:三组六个,阻止默认事件一组,阻止冒泡一组,阻止冒泡和剩余事件一组. 1.事件的默认动作指什么? 比如点a标 ...

  7. JS-特效 ~ 03. 楼层跳跃、事件对象event的获取与使用、event的主要内容、screenX、pageX、clientX的区别、放大镜、模拟滚动条

    楼层跳跃 100%子盒子会继承父盒子的宽高.父盒子继承body宽高.Body继承html的宽高. 盒子属性:auto:适应盒子自身的宽度或者高度.(对自己负责) 盒子属性:100%:适应盒子父盒子的宽 ...

  8. js 事件对象event

    在触发DOM上的某个事件时,会产生一个事件对象event.这个对象中包含着所有与事件有关的信息.包括导致事件的元素,事件的类型以及其他与特定事件相关的信息. <body> <a hr ...

  9. javaScript中的事件对象event是怎样

    事件对象event,每当一个事件被触发的时候,就会随之产恒一个事件对象event,该对象中主要包含了关于该事件的基本属性,事件类型type(click.dbclick等值).目标元素target(我的 ...

随机推荐

  1. 笔记:MyBatis Mapper XML文件详解 - 映射和参数

    MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% ...

  2. 利用国外服务器搭建ss

    wget --no-check-certificate  https://raw.githubusercontent.com/teddysun/shadowsocks_install/master/s ...

  3. 实验楼 -- (Linux)

    1. 允许用户SSH登陆 # 打开ssh配置文件, 一般在/etc/ssh/sshd_config sudo vim /etc/ssh/sshd_config # 在文件最后添加: # 其中shiya ...

  4. Python -- Records项目学习

    Records学习笔记 Records链接地址 1. __getitem__(self, key) 内建方法(Build-in) 例子: class Test(object): def __getit ...

  5. kvm之十二:虚拟机迁移

    虚拟机迁移该方式要确保虚拟机是关机状态.virsh shutdown snalevirsh dumpxml snale > /etc/libvirt/qemu/snale_qy.xml  // ...

  6. 记一次sqoop同步到mysql

    工作中需要用到将hive的数据导一份到mysql中,需求是这样的:hive每天会产生一份用户标签(tag)发生变化的结果表user_tag,这份结果同步到mysql中,并且保持一份全量表,存储当前用户 ...

  7. BLESS学习笔记

    BLESS全称:Bloom-filter-based Error Correction Solution for High-throughput Sequencing Reads,即基于布隆过滤器的高 ...

  8. 移动前端的html5 head 头标签

    DOCTYPE DOCTYPE(Document Type),该声明位于文档中最前面的位置,处于 html 标签之前,此标签告知浏览器文档使用哪种 HTML 或者 XHTML 规范. 使用 HTML5 ...

  9. 2017-2018-1 20155215 第五周 mybash的实现

    题目要求 使用fork,exec,wait实现mybash 写出伪代码,产品代码和测试代码 发表知识理解,实现过程和问题解决的博客(包含代码托管链接) 学习fork,exec,wait fork ma ...

  10. Java作业-集合

    1. 本周学习总结 2. 书面作业 1. ArrayList代码分析 1.1 解释ArrayList的contains源代码 public boolean contains(Object o) { r ...