当前位置: 首页 > news >正文

js事件对象

js事件对象概念说明

在JavaScript中,事件对象是在事件触发时由浏览器自动创建的一个对象。它包含了与事件相关的信息,例如触发事件的元素、事件类型、鼠标的坐标等。

可以通过事件处理函数的第一个参数来访问事件对象。例如,在一个鼠标点击事件处理函数中,可以使用event参数来获取鼠标点击的坐标:

function handleClick(event) {var x = event.clientX;  // 鼠标点击的水平坐标var y = event.clientY;  // 鼠标点击的垂直坐标console.log(x, y);
}

事件对象还包含其他属性和方法,以下是一些常用的属性和方法:

  • event.target:返回触发事件的元素。
  • event.type:返回事件的类型,例如'click'、'mousedown'等。
  • event.preventDefault():取消事件的默认行为。
  • event.stopPropagation():阻止事件冒泡。

js事件对象e的ts类型校验

在TypeScript中,可以使用Event类型来对事件对象进行类型校验。Event是一个内置的基类,它包含了事件对象的常用属性和方法。

首先,需要在事件处理函数中指定事件对象的类型为Event

function handleClick(event: Event) {// 处理事件
}

然后,可以通过类型断言或类型细化来访问事件对象的特定属性。例如,对于鼠标点击事件,可以使用MouseEvent类型来访问鼠标相关的属性:

function handleClick(event: Event) {// 类型断言方式const mouseEvent = event as MouseEvent;const x = mouseEvent.clientX;const y = mouseEvent.clientY;// 类型细化方式if (event instanceof MouseEvent) {const x = event.clientX;const y = event.clientY;}
}

在这里,我们将event对象分别断言为MouseEvent类型和使用instanceof运算符进行类型细化。

需要注意的是,对于不同的事件类型,可能需要使用不同的事件对象类型进行校验。可以查阅相关的文档或参考其他资源来确定正确的事件对象类型。

获取事件对象的兼容

获取事件对象的兼容写法如下:

function getEvent(event) {return event || window.event;
}function getTarget(event) {const eventObj = getEvent(event);return eventObj.target || eventObj.srcElement;
}function preventDefault(event) {const eventObj = getEvent(event);if (eventObj.preventDefault) {eventObj.preventDefault();} else {eventObj.returnValue = false;}
}function stopPropagation(event) {const eventObj = getEvent(event);if (eventObj.stopPropagation) {eventObj.stopPropagation();} else {eventObj.cancelBubble = true;}
}

上述代码中的getEvent函数用于获取事件对象,它先返回传入的事件对象 event,如果不存在则返回 window.event

getTarget函数用于获取事件的目标元素。它首先调用 getEvent 函数获取事件对象,然后根据事件对象的类型来返回目标元素。在现代浏览器中,可以直接使用 event.target。但在兼容旧版 IE 的情况下,需要使用 event.srcElement

preventDefault函数用于阻止事件的默认行为。它先调用 getEvent 函数获取事件对象,然后根据事件对象是否具有 preventDefault 方法来决定如何阻止默认行为。

stopPropagation函数用于阻止事件的冒泡。它也是先调用 getEvent 函数获取事件对象,然后根据事件对象是否具有 stopPropagation 方法来决定如何停止冒泡。

以上代码可以在不同浏览器环境中兼容地处理事件对象的获取和常用操作。

http://www.lryc.cn/news/360361.html

相关文章:

  • 希捷硬盘怎么恢复数据? 5 个免费希捷数据恢复软件
  • Nvidia Jetson/Orin +FPGA+AI大算力边缘计算盒子:京东无人配送机器人
  • STM32作业实现(七)OLED显示数据
  • elementui el-tooltip文字提示组件弹出层内容格式换行处理
  • Python3 笔记:每天一个函数——str.join()
  • 深入解析Python中的None与null:它们真的不同吗?
  • 论文作图之高压缩比导出PDF
  • SpringBoot的启动流程
  • Kubernetes资源调度策略及实现机制
  • finetuning大模型准备(基于Mac环境)
  • js检验一个字符串是否是正确时间格式的工具方法
  • 大型制造业集团IT信息化总体规划方案(65页PPT)
  • 【LIN】STM32新能源汽车LIN通信实现过程
  • 【LeetCode:575. 分糖果+ 哈希表】
  • 全文检索-ElasticSearch
  • C编程惯用法:深入剖析与实战指南
  • MySQL数据表的设计
  • Flutter开发效率提升1000%,Flutter Quick教程之对写好的Widget进行嵌套
  • 2020编程语言排序:探索编程界的热门与趋势
  • 提高工作效率的招数
  • css特殊效果和页面布局
  • JavaScript中对象的增删改查
  • 技术周总结 2024.05.27~06.02(java bean冲突 软件工程)
  • 「前端+鸿蒙」核心技术HTML5+CSS3(八)
  • 15届蓝桥杯决赛,java b组,蒟蒻赛时所写的题思路
  • 2024蓝桥杯国赛C++研究生组游记+个人题解
  • C#WPF数字大屏项目实战07--当日产量
  • MyBatis源码分析--02:SqlSession建立过程
  • SOUI Combobox 实现半透明弹出下拉框
  • Python 猜数系统 PyQt框架 有GUI界面 (源码在最后)【含Python源码 MX_002期】