JavaScript的事件机制详解

发布时间 - 2026-01-10 22:34:21    点击率:

事件是将JavaScript脚本与网页联系在一起的主要方式,是JavaScript中最重要的主题之一,深入理解事件的工作机制以及它们对性能的影响至关重要。本文将详细探讨JavaScript的事件机制,并对比分析了浏览器之间的不同,具体内容包括事件流、事件处理程序绑定方式、事件对象等。

如何理解事件?

JavaScript与HTML之间的交互就是通过事件实现的。

事件:用户或浏览器自身执行的某种动作,换言之,文档或浏览器发生的一些特定的交互瞬间。

事件处理程序:又称事件侦听器,事件发生时执行的代码段。

事件流:事件流描述的是从页面中接收事件的顺序。

两种基本事件模型

事件冒泡:事件按照从最特定的事件目标到最不特定的事件目标(document对象)的顺序触发。

事件捕获:事件从最不精确的对象(document 对象)开始触发,然后到最精确。

IE9、Safari、Chrome、Opera、Firefox都是从window对象开始捕获,冒泡到window对象

DOM事件流

同时支持 两种基本事件模型,规定事件流包括三个阶段:事件捕获阶段、处于目标阶段、事件冒泡阶段。

DOM事件处理程序绑定时,程序员可以自己选择绑定事件时采用事件捕获还是事件冒泡。

IE事件流

IE只支持事件冒泡,不支持事件捕获。

事件处理程序绑定方式

DOM事件处理程序

DOM事件处理程序属性名为“on”+事件名,程序作用域为元素的作用域,this指向元素本身。

方法一:将函数值赋给一个事件处理程序属性。如下:

var btn= document.getElementById("myBtn"); 
btn.onclick = function{ //具体代码段 }

注意:此种方法只能添加一个事件处理程序

方法二:通过addEventListener方法。如下:

addEventListener("事件名",事件处理程序,ture/false:在事件捕获/冒泡阶段调用模型)

对应的事件处理程序移除方法:removeEventListener,参数必须相同。

注意:此种方法,以匿名函数添加的事件处理程序无法被移除

此方法可以添加多个事件处理程序

IE事件处理程序

IE+Oprea浏览器

程序作用域为全局作用域,this指向window对象

添加方法:attachEvent("on+事件名",事件处理程序)

移除方法:detachEvent("on+事件名",事件处理程序)

事件对象

在触发某个事件时,会产生一个相应的事件对象,这个对象包含所有与事件相关的信息。如:导致事件的元素、事件的类型等

DOM中的事件对象

对象名:event

常用属性:

type:被触发事件的类型

target:事件的目标

常用方法:

event.preventDefault:取消事件默认行为(前提:cancelable属性值为true)

event.stopPropagation:取消事件的进一步冒泡或捕获

IE中的事件对象

对象名:window.event

常用属性:

type:被触发事件的类型

scrElement:事件的目标

常用方法:

event.cancelBubble(true/false):true->取消事件默认行为
event.returnValue(true/false):false->取消事件的进一步冒泡或捕获

综合以上所述,整理代码写可跨浏览器的事件处理程序(构造EventUtil对象,为其添加可兼容各浏览器的事件处理方法),如下:

/*可跨浏览器的事件处理程序
构造EventUtil对象,为其添加可兼容各浏览器的事件处理方法
*/
var EventUtil = {
  /*添加事件处理程序*/
  addHandler: function (element, type, handler) {
    if (element.addEventListener) {
      addEventListener(type, handler, false);
    } else if (element.attachEvent) {
      attachEvent("on" + type, handler);
    } else {
      element["on" + type] = handler;
    }
  },
  /*移除事件处理程序*/
  removeHandler: function (element, type, handler) {
    if (element.removeEventListener) {
      removeEventListener(type, handler, false);
    } else if (element.detachEvent) {
      detachEvent("on" + type, handler);
    } else {
      element["on" + type] = null;
    }
  },
  /*获得事件对象*/
  getEvent: function (event) {
    return event ? event : window.event;
  },
  /*获得事件的目标*/
  getTarget: function (event) {
    return event.target || event.scrElement;
  },
  /*取消事件的默认行为*/
  preventDefault: function (event) {
    if (event.preventDefault) {
      event.preventDefault;
    } else {
      event.returValue = false;
    }
  },
  /*阻止事件进一步冒泡*/
  stopPropagation: function (event) {
    if (event.stopPropagation) {
      event.stopPropagation;
    } else {
      event.cancelBubble = true;
    }
  }
};

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# JavaScript  # 事件机制  # js事件机制----捕获与冒泡机制实例分析  # JS 事件机制完整示例分析  # JS内部事件机制之单线程原理  # 利用Javascript实现一套自定义事件机制  # 深入理解JavaScript事件机制  # 移除  # 绑定  # 两种  # 是从  # 为其  # 此种  # 最不  # 多个  # 最重要  # 不支持  # 并对  # 内容包括  # 至关重要  # 所述  # 值为  # 工作机制  # 三个阶段  # 瞬间  # 文档  # js 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 手机网站制作与建设方案,手机网站如何建设?  javascript基本数据类型及类型检测常用方法小结  html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】  简单实现jsp分页  Python函数文档自动校验_规范解析【教程】  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  动图在线制作网站有哪些,滑动动图图集怎么做?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】  Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  无锡营销型网站制作公司,无锡网选车牌流程?  如何用PHP快速搭建CMS系统?  韩国服务器如何优化跨境访问实现高效连接?  深圳网站制作平台,深圳市做网站好的公司有哪些?  高防服务器:AI智能防御DDoS攻击与数据安全保障  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  海南网站制作公司有哪些,海口网是哪家的?  如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框  python中快速进行多个字符替换的方法小结  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  Laravel如何使用withoutEvents方法临时禁用模型事件  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  教你用AI将一段旋律扩展成一首完整的曲子  如何在建站宝盒中设置产品搜索功能?  HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】  如何在阿里云域名上完成建站全流程?  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  如何在阿里云部署织梦网站?  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址  大学网站设计制作软件有哪些,如何将网站制作成自己app?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧  IOS倒计时设置UIButton标题title的抖动问题  js代码实现下拉菜单【推荐】  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  JavaScript如何实现类型判断_typeof和instanceof有什么区别  微信小程序 闭包写法详细介绍  如何快速搭建二级域名独立网站?  Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例  ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  用yum安装MySQLdb模块的步骤方法  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  个人网站制作流程图片大全,个人网站如何注销?  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  详解vue.js组件化开发实践  Android实现代码画虚线边框背景效果