js之事件系统

事件系统

use 1 n use EventBus Event EventListener

EventListener:以函数形式表示
Event:事件对象数据,对于不同的事件,包含不同的数据

事件阶段

事件处理程序

DOM0方式为:元素.on<事件名> = 函数,调用是在冒泡阶段

DOM2方式为:使用addEventListener添加事件处理函数,有三个参数

  • 事件名,没有前缀on
  • 事件处理程序
  • 在哪个阶段调用触发:false表示在冒泡阶段,true表示在捕获阶段,默认是在冒泡阶段

事件对象

包含下面一些属性
type:表示事件类型,数据类型为字符串
target:表示事件目标
currentTarget:事件处理程序所在的元素
eventPhase:表示事件阶段,1表示捕获阶段,2表示到达目标,3表示冒泡阶段

其支持的事件有

用户界面事件UIEvent


load:表示window页面加载完;frameset中的frame加载完;img图片加载完;object元素加载完
unload:从一页面到另一页面时触发,其支持的情况有

  • window页面完全缷载
  • object上对象缷载完成后

abort:表示在加载过程中用户中止
error:在下面情况时触发

  • window上js报错时
  • img无法加载图片时
  • object上无法加载相应对象
  • frameset上frame无法加载时

select:文本框(input,textArea)中用户选择了字符时
resize:window,frame窗口缩放时
scroll:有滚动条元素时,用户滚动时触发

焦点事件FocusEvent


focus,blur:为不冒泡版的获取焦点,失去焦点事件,是通用版
focusIn, focusOut:为冒泡版的获取焦点,失去焦点事件,是通用版
DOMFocusIn, DOMFocusOut:为特定浏览器支持的获取焦点,失去信息事件,不是通用版的

相关推荐
前端老宋Running8 小时前
“受控组件”的诅咒:为什么你需要 React Hook Form + Zod 来拯救你的键盘?
前端·javascript·react.js
阿蒙Amon8 小时前
JavaScript学习笔记:7.数字和字符串
javascript·笔记·学习
Highcharts.js8 小时前
官方文档|Angular 框架集成 Highcharts Dashboards
前端·javascript·angular.js·highcharts·看板·使用文档·dashboards
韭菜炒大葱8 小时前
React 新手村通关指南:状态、组件与魔法 UI 🧙‍♂️
前端·javascript·react.js
小明记账簿9 小时前
JavaScript浮点数精度问题及解决方案
开发语言·javascript·ecmascript
1024肥宅9 小时前
JavaScript性能与优化:手写实现关键优化技术
前端·javascript·面试
一字白首9 小时前
Vue 项目实战,从注册登录到首页开发:接口封装 + 导航守卫 + 拦截器全流程
前端·javascript·vue.js
沐浴露z10 小时前
详解Javascript精度丢失以及解决方案
java·javascript
今天不要写bug10 小时前
基于qrcode前端实现链接转二维码的生成与下载
前端·javascript·typescript·vue