idea中event log_【JavaScript 教程】事件——Event 对象

08d7ee59c3c30bcd5acf7288806fd2af.png

作者 | 阮一峰

概述

事件发生以后,会产生一个事件对象,作为参数传给监听函数。浏览器原生提供一个Event对象,所有的事件都是这个对象的实例,或者说继承了Event.prototype对象。

Event对象本身就是一个构造函数,可以用来生成新的实例。

event = new Event(type, options);

Event构造函数接受两个参数。第一个参数type是字符串,表示事件的名称;第二个参数options是一个对象,表示事件对象的配置。该对象主要有下面两个属性。

  • bubbles:布尔值,可选,默认为false,表示事件对象是否冒泡。

  • cancelable:布尔值,可选,默认为false,表示事件是否可以被取消,即能否用Event.preventDefault()取消这个事件。一旦事件被取消,就好像从来没有发生过,不会触发浏览器对该事件的默认行为。

var ev = new Event(
'look',
{
'bubbles': true,
'cancelable': false
}
);
document.dispatchEvent(ev);

上面代码新建一个look事件实例,然后使用dispatchEvent方法触发该事件。

注意,如果不是显式指定bubbles属性为true,生成的事件就只能在“捕获阶段”触发监听函数。

// HTML 代码为
//

Hello


var div = document.querySelector('div');
var p = document.querySelector('p');

function callback(event) {
var tag = event.currentTarget.tagName;
console.log('Tag: ' + tag); // 没有任何输出
}

div.addEventListener('click', callback, false);

var click = new Event('click');
p.dispatchEvent(click);

上面代码中,p元素发出一个click事件,该事件默认不会冒泡。div.addEventListener方法指定在冒泡阶段监听,因此监听函数不会触发。如果写成div.addEventListener('click', callback, true),那么在“捕获阶段”可以监听到这个事件。

另一方面,如果这个事件在div元素上触发。

div.dispatchEvent(click);

那么,不管div元素是在冒泡阶段监听,还是在捕获阶段监听,都会触发监听函数。因为这时div元素是事件的目标,不存在是否冒泡的问题,div元素总是会接收到事件,因此导致监听函数生效。

实例属性

Event.bubbles,Event.eventPhase

Event.bubbles属性返回一个布尔值,表示当前事件是否会冒泡。该属性为只读属性,一般用来了解 Event 实例是否可以冒泡。前面说过,除非显式声明,Event构造函数生成的事件,默认是不冒泡的。

Event.eventPhase属性返回一个整数常量,表示事件目前所处的阶段。该属性只读。

var phase = event.eventPhase;

Event.eventPhase的返回值有四种可能。

  • 0,事件目前没有发生。

  • 1,事件目前处于捕获阶段,即处于从祖先节点向目标节点的传播过程中。

  • 2,事件到达目标节点,即Event.target属性指向的那个节点。

  • 3,事件处于冒泡阶段,即处于从目标节点向祖先节点的反向传播过程中。

Event.cancelable,Event.cancelBubble,event.defaultPrevented

Event.cancelable属性返回一个布尔值,表示事件是否可以取消。该属性为只读属性,一般用来了解 Event 实例的特性。

大多数浏览器的原生事件是可以取消的。比如,取消click事件,点击链接将无效。但是除非显式声明,Event构造函数生成的事件,默认是不可以取消的。

var evt = new Event('foo');
evt.cancelable // false

Event.cancelable属性为true时,调用Event.preventDefault()就可以取消这个事件,阻止浏览器对该事件的默认行为。

如果事件不能取消,调用Event.preventDefault()会没有任何效果。所以使用这个方法之前,最好用Event.cancelable属性判断一下是否可以取消。

function preventEvent(event) {
if (event.cancelable) {
event.preventDefault();
} else {
console.warn('This event couldn\'t be canceled.');
console.dir(event);
}
}

Event.cancelBubble属性是一个布尔值,如果设为true,相当于执行Event.stopPropagation(),可以阻止事件的传播。

Event.defaultPrevented属性返回一个布尔值,表示该事件是否调用过Event.preventDefault方法。该属性只读。

if (event.defaultPrevented) {
console.log('该事件已经取消了');
}

Event.currentTarget,Event.target

Event.currentTarget属性返回事件当前所在的节点,即正在执行的监听函数所绑定的那个节点。

Event.target属性返回原始触发事件的那个节点,即事件最初发生的节点。事件传播过程中,不同节点的监听函数内部的Event.targetEvent.currentTarget属性的值是不一样的,前者总是不变的,后者则是指向监听函数所在的那个节点对象。

// HTML代码为
//

Hello World


function hide(e) {
console.log(this === e.currentTarget); // 总是 true
console.log(this === e.target); // 有可能不是 true
e.target.style.visibility = 'hidden';
}

para.addEventListener('click', hide, false);

上面代码中,如果在para节点的子节点上面点击,则e.target指向子节点,导致子节点(即 World 部分)会不可见。如果点击 Hello 部分,则整个para都将不可见。

Event.type

Event.type属性返回一个字符串,表示事件类型。事件的类型是在生成事件的时候指定的。该属性只读。

var evt = new Event('foo');
evt.type // "foo"

Event.timeStamp

Event.timeStamp属性返回一个毫秒时间戳,表示事件发生的时间。它是相对于网页加载成功开始计算的。

var evt = new Event('foo');
evt.timeStamp // 3683.6999999995896

它的返回值有可能是整数,也有可能是小数(高精度时间戳),取决于浏览器的设置。

下面是一个计算鼠标移动速度的例子,显示每秒移动的像素数量。

var previousX;
var previousY;
var previousT;

window.addEventListener('mousemove', function(event) {
if (
previousX !== undefined &&
previousY !== undefined &&
previousT !== undefined
) {
var deltaX = event.screenX - previousX;
var deltaY = event.screenY - previousY;
var deltaD = Math.sqrt(Math.pow(deltaX, 2) + Math.pow(deltaY, 2));

var deltaT = event.timeStamp - previousT;
console.log(deltaD / deltaT * 1000);
}

previousX = event.screenX;
previousY = event.screenY;
previousT = event.timeStamp;
});

Event.isTrusted

Event.isTrusted属性返回一个布尔值,表示该事件是否由真实的用户行为产生。比如,用户点击链接会产生一个click事件,该事件是用户产生的;Event构造函数生成的事件,则是脚本产生的。

var evt = new Event('foo');
evt.isTrusted // false

上面代码中,evt对象是脚本产生的,所以isTrusted属性返回false

Event.detail

Event.detail属性只有浏览器的 UI (用户界面)事件才具有。该属性返回一个数值,表示事件的某种信息。具体含义与事件类型相关。比如,对于clickdblclick事件,Event.detail是鼠标按下的次数(1表示单击,2表示双击,3表示三击);对于鼠标滚轮事件,Event.detail是滚轮正向滚动的距离,负值就是负向滚动的距离,返回值总是3的倍数。

// HTML 代码如下
//

Hello


function giveDetails(e) {
console.log(e.detail);
}

document.querySelector('p').onclick = giveDetails;

实例方法

Event.preventDefault()

Event.preventDefault方法取消浏览器对当前事件的默认行为。比如点击链接后,浏览器默认会跳转到另一个页面,使用这个方法以后,就不会跳转了;再比如,按一下空格键,页面向下滚动一段距离,使用这个方法以后也不会滚动了。该方法生效的前提是,事件对象的cancelable属性为true,如果为false,调用该方法没有任何效果。

注意,该方法只是取消事件对当前元素的默认影响,不会阻止事件的传播。如果要阻止传播,可以使用stopPropagation()stopImmediatePropagation()方法。

// HTML 代码为
//
var cb = document.getElementById('my-checkbox');

cb.addEventListener(
'click',
function (e){ e.preventDefault(); },
false
);

上面代码中,浏览器的默认行为是单击会选中单选框,取消这个行为,就导致无法选中单选框。

利用这个方法,可以为文本输入框设置校验条件。如果用户的输入不符合条件,就无法将字符输入文本框。

// HTML 代码为
//
var input = document.getElementById('my-input');
input.addEventListener('keypress', checkName, false);

function checkName(e) {
if (e.charCode < 97 || e.charCode > 122) {
e.preventDefault();
}
}

上面代码为文本框的keypress事件设定监听函数后,将只能输入小写字母,否则输入事件的默认行为(写入文本框)将被取消,导致不能向文本框输入内容。

Event.stopPropagation()

stopPropagation方法阻止事件在 DOM 中继续传播,防止再触发定义在别的节点上的监听函数,但是不包括在当前节点上其他的事件监听函数。

function stopEvent(e) {
e.stopPropagation();
}

el.addEventListener('click', stopEvent, false);

上面代码中,click事件将不会进一步冒泡到el节点的父节点。

Event.stopImmediatePropagation()

Event.stopImmediatePropagation方法阻止同一个事件的其他监听函数被调用,不管监听函数定义在当前节点还是其他节点。也就是说,该方法阻止事件的传播,比Event.stopPropagation()更彻底。

如果同一个节点对于同一个事件指定了多个监听函数,这些函数会根据添加的顺序依次调用。只要其中有一个监听函数调用了Event.stopImmediatePropagation方法,其他的监听函数就不会再执行了。

function l1(e){
e.stopImmediatePropagation();
}

function l2(e){
console.log('hello world');
}

el.addEventListener('click', l1, false);
el.addEventListener('click', l2, false);

上面代码在el节点上,为click事件添加了两个监听函数l1l2。由于l1调用了event.stopImmediatePropagation方法,所以l2不会被调用。

Event.composedPath()

Event.composedPath()返回一个数组,成员是事件的最底层节点和依次冒泡经过的所有上层节点。

// HTML 代码如下
//
//

Hello

//

var div = document.querySelector('div');
var p = document.querySelector('p');

div.addEventListener('click', function (e) {
console.log(e.composedPath());
}, false);
// [p, div, body, html, document, Window]

上面代码中,click事件的最底层节点是p,向上依次是divbodyhtmldocumentWindow

454cbaa1f7071882ce7bb720be35fa86.png

7ac54485110880ae20d7e0b3daeba556.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/489140.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

谷歌新智能体Dreamer将亮相NeurIPS 2019,数据效率比前身PlaNet快8个小时

来源&#xff1a;雷锋网在具有挑战性的环境中&#xff0c;一些人工智能系统通过利用过去经验所提供的世界表象来实现目标。研究人员将这些应用推广到新的情况&#xff0c;使它们能够在以前从未遇到过的环境中完成任务。事实证明&#xff0c;强化学习——一种使用奖励来推动软件…

mysql 游标总条数_mysql 游标的使用总结

一、游标的基本概念游标&#xff1a;游标是一个存储在Mysql服务器上的数据库查询&#xff0c;它不是一条select语句&#xff0c;而是被该语句检索出来的结果集。本人&#xff0c;学习游标中&#xff0c;曾遇到一个问题&#xff0c;循环总是最后多执行一次。下面分析程序&#x…

AR行业成本拆解解析

来源&#xff1a;三极光电科技一、AR 产业简介&#xff08;一&#xff09;AR 定义AR 技术&#xff08;AugmentedReality&#xff0c;AR&#xff09;是借助光电显示技术、交互技术、多种传感技术和计算机图形与多媒体技术将计算机生成的虚拟环境与用户周围的真实环境融为一体&am…

mimo雷达信号处理_雷达学术入门脉冲雷达信号处理概述

Reviewed by &#xff1a;甜草莓 Robert Zhou&#xff1b;前置知识&#xff1a;概率论与统计学。面向人群&#xff1a;本科生、研究生/信号处理博士。 编者&#xff1a;对于信号处理来说&#xff0c;雷达和通信一直是一体两面&#xff0c;从MIMO通信到MIMO雷达&#xff0c;从OF…

人类历史十大经典物理实验,有些实验就在你身边为何你没注意到?

来源&#xff1a;数学职业家实验是科学研究的基本方法之一&#xff0c;也是人类认识自然现象、自然性质、自然规律的途径。现代实验技术的发展&#xff0c;不断地揭示和发现各种新的物理现象&#xff0c;日益加深人们对客观世界规律的正确认识&#xff0c;从而推动物理学的向前…

一、linux搭建jenkins+github详细步骤

事情缘由&#xff1a; 现在在做的主要工作是通过jenkinspostman实现api的自动化测试&#xff0c;想要达到的效果是&#xff0c;api自动化测试定时跑脚本的同时&#xff0c;github有新的代码提交&#xff0c;jenkins会自动检测部署新提交的代码&#xff0c;并且再次将api自动化脚…

matlab插值与拟合例题_MATLAB中数据插值和数据拟合的用法

一、数据插值&#xff1a;插值是在一组已知数据点的范围内添加新数据点的技术。可以使用插值来填充缺失的数据、对现有数据进行平滑处理以及进行预测等。MATLAB 中的插值技术可分为适用于网格上的数据点和散点数据点。从数学上来说&#xff0c;数据插值是一种函数逼近的方法。数…

半导体行业深度报告:从应用到行业的全面复苏

来源&#xff1a;国金证券一、2020-2021年全球半导体市场投资展望多种因素导致全球半导体市场于 2019 年同比下跌近 13%到 4,102 亿美元&#xff0c;而存储器行业同比下跌超过 30%&#xff0c;逻辑半导体同比下跌近 2%。存储器市场占全球半导体市场达到近三年低点的 27%。但受惠…

mysql 8 修改root密码忘记_忘记mysql8或者mariadb5及以上 的root密码如何更改

实验环境操作系统&#xff1a;lsb_release -aNo LSB modules are available.Distributor ID:UbuntuDescription:Ubuntu 20.04.1 LTSRelease:20.04Codename:focalmysql数据库版本&#xff1a;mysql基本信息具体步骤1. 停止mysql (sudo service mysqld stop 或者 kill -TERM mysq…

配置tomcat_Tomcat 配置必备的 10 个小技巧,让你轻松玩转Tomcat

现在开发Java Web应用&#xff0c;建立和部署Web内容是一件很简单的工作。使用Jakarta Tomcat作为Servlet和JSP容器的人已经遍及全世界。Tomcat具有免费、跨平台等诸多特性&#xff0c;并且更新得很快&#xff0c;现在非常的流行。你所需要做的就是&#xff1a;按照你的需求配置…

卫星移动通信现状与未来发展

来源&#xff1a;电子万花筒摘要&#xff1a;卫星移动通信系统具有覆盖范围广&#xff0c;对地面情况不敏感等优势&#xff0c;已经成为地面移动通信领域重要的组成部分&#xff0c;尤其是在空中、海洋、荒漠戈壁等地面无线网络难以覆盖的地方。随着科学技术的不断进步&#xf…

mysql load data infile 重写_mysql load data infile 命令的数据导入

文章介绍了mysql load data infile 命令的数据导入&#xff0c;该方式比直接的insert的效率要高&#xff0c;按照官方的说法是要比insert语句快上20倍,有需要的朋友可参考。使用方式如下&#xff1a;代码如下复制代码mysql>load data local infile "D:/ab.txt" in…

DARPA发布战略框架文件旨在 为美国国家安全创建突破性新技术能力

来源&#xff1a;ARPA网站/图片来自互联网12月4日&#xff0c;DARPA公开了于今年8月份完成的2019年度战略框架文件《面向国家安全创建技术突破和新能力》&#xff0c;阐述了该机构面临的威胁环境&#xff0c;并提出了未来几年的发展计划。1应关注的重点该框架文件指出&#xff…

rust矿洞绳子怎么爬下_rust矿洞绳子怎么爬下_打工小伙爬冰救人,每动一下都能听到冰面碎裂声...

近日&#xff0c;在辽宁沈阳鲁迅公园&#xff0c;一男子掉进湖中冰窟窿&#xff0c;露出脑袋不停地呼救。生死时刻&#xff0c;一位正在附近找零活的小伙&#xff0c;不顾冰面碎裂发出的咔咔声&#xff0c;一步步爬冰救人&#xff0c;最终在岸上众人帮助下&#xff0c;成功救出…

Python爬虫入门四之Urllib库的高级用法

1.设置Headers 有些网站不会同意程序直接用上面的方式进行访问&#xff0c;如果识别有问题&#xff0c;那么站点根本不会响应&#xff0c;所以为了完全模拟浏览器的工作&#xff0c;我们需要设置一些Headers 的属性。 首先&#xff0c;打开我们的浏览器&#xff0c;调试浏览器F…

Magic Leap 价值 20 多亿美元的 AR 幻梦,现在醒了

来源&#xff1a;传感器技术那个用特效来吹出 AR 神话的 Magic Leap&#xff0c;终于有了新动静。 当地时间 12 月 10 日&#xff0c;增强现实&#xff08;AR&#xff09;领域的“知名”公司 Magic Leap 宣布&#xff0c;将 Magic Leap One Creator Edition 改名为 Magic Leap …

mysql约束_不是吧,阿Sir,MySQL约束你竟然还不懂!

以前写的太乱了&#xff0c;翻出来重新整理下系列目录&#xff1a;MySQL入门&#xff0c;问题不大【增删改查极速上手】(一) 引入约束(1) 约束出现在哪里&#xff1f; 想要讲解约束&#xff0c;就要知道约束用在哪里&#xff0c;用来干嘛&#xff1f;SQL 语言通过定义一个关系所…

dc持久内存与mysql_Calypso Systems推出测试软件和服务器测试傲腾数据中心级持久内存...

Calypso Systems测试Optane DCPMM(DC Persistent Memory Module 数据中心级持久性内存模块)的性能&#xff0c;带宽超过36500MB/s(顺序读写速度128000MB/s)&#xff0c;每秒读写速度为3240万IOPS(顺序读取速度5000)&#xff0c;平均响应时间达到0.11微秒。Calypso PM(持久性内存…

计算机行业研究及2020年策略:聚焦主赛道,投资真成长(84页)

来源&#xff1a;国元证券1、行业涨幅位居前列&#xff0c;个股表现精彩纷呈……2、IT 产业大变革&#xff0c;新机遇不断涌现近年来&#xff0c;以 5G、物联网、云计算、大数据、人工智能、区块链等技术为代表的信息 科技行业快速发展&#xff0c;新兴技术不断涌现&#xff0c…

最长回文串_第78天——第78题(最长回文串 )

今天又是阴天&#xff0c;不过阴天凉快&#xff0c;我喜欢。第78天——第78题&#xff08;最长回文串&#xff09;看题目&#xff01;给定一个包含大写字母和小写字母的字符串&#xff0c;找到通过这些字母构造成的最长的回文串。在构造过程中&#xff0c;请注意区分大小写。比…