JavaScript常见事件对象与操作实例总结


Posted in Javascript onJanuary 05, 2019

本文实例讲述了JavaScript常见事件对象与操作。分享给大家供大家参考,具体如下:

触发 DOM 上的事件时,会生成一个事件对象 event,它包含着所有与事件有关的信息,诸如导致事件的元素、事件的类型以及其他与特定事件相关的信息。所有的浏览器都支持 event 对象,但支持的方式不同。

1 DOM 中的事件对象

兼容 DOM 的浏览器会将 event 对象传入事件处理程序(DOM0 级与 DOM2 级都支持):

var btn = document.getElementById("myBtn");
btn.onclick = function (event) {
  console.log(event.type);//"click"
};
btn.addEventListener("click",function(event){
  console.log(event.type);//"click"
,false};

event.type 保存的是被触发的事件类型。

通过 HTML 属性指定事件处理程序时, event 中保存的是 event 对象:

<input type="button" value="Click Me" onclick="alert(event.type)"/>

event 对象包含着创建它的特定事件相关的属性和方法,所以可能每个特定事件都有自己所特有的属性和方法,不过所有事件都会有这些属性和方法:

属性/方法 类型 读/写 说明
bubbles Boolean 只读 事件是否冒泡。
cancelable Boolean 只读 是否可以取消事件的默认行为。
currentTarget Element 只读 与当前事件处理程序相关的元素。
defaultPrevented Boolean 只读 true 表示已调用 preventDefault() 方法(DOM3 新增)。
detail Integer 只读 与事件相关的细节信息。
eventPhase Integer 只读 调用事件处理程序的阶段;1:捕获;2:处于目标;3:冒泡。
preventDefault() Function 只读 取消事件的默认行为(如果 cancelable 为 true,就可以调用这个方法)。
stopImmediatePropagation() Function 只读 阻止事件被进一步捕获或者冒泡,同时阻止任何事件处理程序被调用(DOM3 新增)。
stopPropagation() Function 只读 阻止事件被进一步捕获或者冒泡(如果 bubbles 为 true,就可以调用这个方法)。
target Element 只读 事件的目标。
trusted Boolean 只读 true:事件是由浏览器生成的;false:事件是通过 JavaScript 创建的(DOM3 新增)。
type String 只读 被触发的事件类型。
view AbstractView 只读 与事件相关的抽象视图,相当于发生事件的 window 对象。

在事件处理程序内部,this 始终等于 currentTarget,而 target 等于事件的实际目标。如果直接将事件处理程序指定给目标元素,那么这三个值相等:

<script type="text/javascript">
  var btn = document.getElementById("myBtn");
  btn.onclick = function (event) {
    console.log(event.currentTarget === this);//true
    console.log(event.target === this);//true
  }
</script>

如果事件处理程序指定到按钮的父节点上,那么它们是不同的:

<script type="text/javascript">
  document.body.onclick = function (event) {
    console.log(event.currentTarget === document.body);//true
    console.log(this === document.body);//true
    console.log(event.target === document.getElementById("myBtn"));//true
  }
</script>

如果需要通过一个函数来处理多个事件,那么可以使用 type 属性:

<script type="text/javascript">
  var btn = document.getElementById("myBtn");
  var handler = function (event) {
    switch (event.type) {
      case "click":
        console.log("Clicked");
        break;
      case "mouseover":
        event.target.style.backgroundColor = "red";
        break;
      case "mouseout":
        event.target.style.backgroundColor = "";
        break;
    }
  };
  btn.onclick = handler;
  btn.onmouseover = handler;
  btn.onmouseout = handler;
</script>

使用 preventDefault() 方法来阻止特定事件的默认行为:

<a id="myLink" href="163.com" rel="external nofollow" rel="external nofollow" >点我</a>
<script type="text/javascript">
  var link = document.getElementById("myLink");
  link.onclick = function (event) {
    event.preventDefault();
  }
</script>

注意:只有 cancelable 属性值为 true 的事件,才可以使用 preventDefault() 阻止特定事件的默认行为!

stopPropagation() 会立即阻止事件在 DOM 层次的传播。比如这里在按钮事件中调用 stopPropagation() ,来避免触发注册在 document.body 上的事件处理程序:

<script type="text/javascript">
  var btn = document.getElementById("myBtn");
  btn.onclick = function (event) {
    console.log("Clicked");
    event.stopPropagation();
  };
  document.body.onclick = function (event) {
    console.log("Body clicked");
  };
</script>

eventPhase 属性,可以确定事件当前正处于事件流的哪一个阶段:

<script type="text/javascript">
  var btn = document.getElementById("myBtn");
  btn.onclick = function (event) {
    console.log(event.eventPhase);//2
  };
  document.body.addEventListener("click", function (event) {
    console.log(event.eventPhase);//1
  }, true);//true 表示捕获阶段
  document.body.onclick = function (event) {
    console.log(event.eventPhase);//3
  };
</script>

注意: 只有在事件处理程序执行期间,event 对象才会存在;一旦事件处理程序执行结束,event 对象就会被销毁!

2 IE 中的事件对象

在使用 DOM0 级方法添加事件处理程序时,event 对象是作为 window 对象的一个属性存在:

var btn = document.getElementById("myBtn");
btn.onclick = function () {
  var event = window.event;
  console.log(event.type);//"click"
};

如果是通过 HTML 属性指定的事件处理程序,也跟 DOM一样,可以通过 event 变量来访问 event 对象。

IE 的 event 对象也包含着创建它的特定事件相关的属性和方法,所以可能每个特定事件都有自己所特有的属性和方法,不过所有事件都会有这些属性和方法:

属性 类型 读/写 说明
cancelBubble Boolean 读/写 默认值为 false,true 表示可以取消事件冒泡(同 DOM 的 stopPropagation() )。
returnValue Boolean 读/写 默认值为 true,false 表示取消事件默认行为(同 DOM 的 preventDefault() )。
srcElement Element 只读 事件的目标(同 DOM 中的 target)。
type String 只读 被触发的事件类型。

因为事件处理程序的作用域是根据它指定的方式来确定的,所以最好是使用 event.srcElement 来得到事件的目标比较靠谱:

<button id="myBtn">点我</button>
<script type="text/javascript">
  var btn = document.getElementById("myBtn");
  btn.onclick = function () {
    console.log(window.event.srcElement === this);//true
  };
  btn.attachEvent("onclick", function (event) {
    console.log(event.srcElement === this);//false
  });
</script>

将 returnValue 设置为 false,就能阻止默认行为:

<a id="myLink" href="163.com" rel="external nofollow" rel="external nofollow" >点我</a>
<script type="text/javascript">
  var link = document.getElementById("myLink");
  link.onclick = function () {
    window.event.returnValue = false;
  }
</script>

与 DOM 不同的是,这里没有办法确定事件是否能被取消。

因为 IE 不支持事件捕获,所以只能取消事件冒泡:

<script type="text/javascript">
  var btn = document.getElementById("myBtn");
  btn.onclick = function () {
    console.log("Clicked");
    window.event.cancelBubble = true;
  };
  document.body.onclick = function (event) {
    console.log("Body clicked");
  };
</script>

3 跨浏览器的事件对象

我们把之前的 EventUtil 对象进行增强:

var EventUtil = {
  ...
  /**
   * 返回对 event 对象的引用
   * @param event
   * @returns {*}
   */
  getEvent: function (event) {
    return event ? event : window.event;
  },
  /**
   * 返回事件的目标
   * @param event
   * @returns {*|elem|Object}
   */
  getTarget: function (event) {
    return event.target || event.srcElement;
  },
  /**
   * 取消事件默认行为
   * @param event
   */
  preventDefault: function (event) {
    if (event.preventDefault) {
      event.preventDefault();
    } else {
      event.returnValue = false;
    }
  },
  /**
   * 阻止事件流
   * @param event
   */
  stopPropagation: function (event) {
    if (event.stopPropagation) {
      event.stopPropagation();
    } else {
      event.cancelBubble = true;
    }
  }
}

这样使用:

<button id="myBtn">点我</button>
<script type="text/javascript">
  var btn = document.getElementById("myBtn");
  btn.onclick = function (event) {
    event = EventUtil.getEvent(event);//确保所有浏览器都能使用 event 对象
    var target = EventUtil.getTarget(event);
    console.log(target);
  }
</script>

取消事件默认行为:

<a id="myLink" href="http://www.163.com" rel="external nofollow" >点我</a>
<script type="text/javascript">
  var link = document.getElementById("myLink");
  link.onclick = function (event) {
    event = EventUtil.getEvent(event);
    EventUtil.preventDefault(event);
  }
</script>

阻止事件传播:

<button id="myBtn">点我</button>
<script type="text/javascript">
  var btn = document.getElementById("myBtn");
  btn.onclick = function (event) {
    console.log("Clicked");
    event = EventUtil.getEvent(event);
    EventUtil.stopPropagation(event);
  };
  document.body.onclick = function (event) {
    console.log("Body clicked");
  };
</script>

因为 IE 不支持事件捕获,所以 EventUtil 的 stopPropagation() 的方法只能阻止事件冒泡。

PS:关于javascript事件说明可参考本站javascript事件与功能说明大全:http://tools.3water.com/table/javascript_event

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
Javascript实例教程(19) 使用HoTMetal(1)
Dec 23 Javascript
jquery 获取json数据实现代码
Apr 27 Javascript
JS实现遮罩层效果的简单实例
Nov 12 Javascript
jquery实现页面关键词高亮显示的方法
Mar 12 Javascript
原生js实现addClass,removeClass,hasClass方法
Apr 27 Javascript
javascript jquery对form元素的常见操作详解
Jun 12 Javascript
实例详解jQuery的无new构建
Aug 02 Javascript
jQuery实现radio第一次点击选中第二次点击取消功能
May 15 jQuery
vue.js实现备忘录功能的方法
Jul 10 Javascript
Angular2关于@angular/cli默认端口号配置的问题
Jul 15 Javascript
JavaScript页面倒计时功能完整示例
May 15 Javascript
vue 在服务器端直接修改请求的接口地址
Dec 19 Vue.js
JavaScript常见事件处理程序实例总结
Jan 05 #Javascript
JavaScript代码调试方法实例小结
Jan 05 #Javascript
JavaScript实现连连看连线算法
Jan 05 #Javascript
JavaScript错误处理操作实例详解
Jan 04 #Javascript
JSON基本语法及与JavaScript的异同实例分析
Jan 04 #Javascript
JavaScript解析及序列化JSON的方法实例分析
Jan 04 #Javascript
Node.js操作系统OS模块用法分析
Jan 04 #Javascript
You might like
使用php判断浏览器的类型和语言的函数代码
2013/02/28 PHP
php缓冲 output_buffering的使用详解
2013/06/13 PHP
与文件上传有关的php配置参数总结
2013/06/14 PHP
php调用Google translate_tts api实现代码
2013/08/07 PHP
PHP验证码类ValidateCode解析
2017/01/07 PHP
PHP自定义函数实现assign()数组分配到模板及extract()变量分配到模板功能示例
2018/05/23 PHP
php服务器的系统详解
2019/10/12 PHP
JQuery 学习笔记 选择器之二
2009/07/23 Javascript
Javascript学习笔记二 之 变量
2010/12/15 Javascript
js+html+css实现鼠标移动div实例
2013/01/30 Javascript
JavaScript对象的property属性详解
2014/04/01 Javascript
js预加载图片方法汇总
2015/06/15 Javascript
Javascript中call,apply,bind方法的详解与总结
2016/12/12 Javascript
JS实现物体带缓冲的间歇运动效果示例
2016/12/22 Javascript
jQuery判断邮箱格式对错实例代码讲解
2017/04/12 jQuery
webpack构建的详细流程探底
2018/01/08 Javascript
Layui实现数据表格默认全部显示(不要分页)
2019/10/26 Javascript
Ant Design Pro 下实现文件下载的实现代码
2019/12/03 Javascript
vue 实现用户登录方式的切换功能
2020/04/14 Javascript
JavaScript实现商品评价五星好评
2020/11/30 Javascript
[44:09]DOTA2上海特级锦标赛A组小组赛#1 EHOME VS MVP.Phx第二局
2016/02/25 DOTA
Mac下Supervisor进程监控管理工具的安装与配置
2014/12/16 Python
Python 在字符串中加入变量的实例讲解
2018/05/02 Python
Python根据字符串调用函数过程解析
2020/11/05 Python
洲际酒店集团大中华区:IHG中国
2016/08/17 全球购物
韩国邮政旗下生鲜食品网上超市:epost
2016/08/27 全球购物
Rosetta Stone官方网站:语言学习
2019/01/05 全球购物
银行会计职员个人的自我评价
2013/09/29 职场文书
医院实习接收函
2014/01/12 职场文书
道德之星事迹材料
2014/05/03 职场文书
政府绩效管理实施方案
2014/05/04 职场文书
五年级上册复习计划
2015/01/19 职场文书
中班下学期个人工作总结
2015/02/12 职场文书
2015年幼儿园安全工作总结
2015/05/12 职场文书
pytorch finetuning 自己的图片进行训练操作
2021/06/05 Python
阿里云k8s服务升级时502错误 springboot项目应用
2022/04/09 Servers