位置: 编程技术 - 正文

JavaScript事件处理的方式(三种)

编辑:rootadmin

推荐整理分享JavaScript事件处理的方式(三种),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

最近这段时间因为每天要修改网站,为网站做特效,所以看了很多的js接触事件,自己只会使用一小部分,有时用的时候也比较混乱,现在系统的整理了一下,特此分享到积木网平台供大家参考下!

一、什么是JavaScript事件?

事件(Event)是JavaScript应用跳动的心脏,也是把所有东西粘在一起的胶水,当我们与浏览器中Web页面进行某些类型的交互时,事件就发生了。

事件可能是用户在某些内容上的点击、鼠标经过某个特定元素或按下键盘上的某些按键,事件还可能是Web浏览器中发生的事情,比如说某个Web页面加载完成,或者是用户滚动窗口或改变窗口大小。说白了,事件是文档或浏览器中发生的特定交互瞬间!

通过使用JavaScript,你可以监听特定事件的发生,并规定让某些事件发生以对这些事件做出响应。

二、事件流

事件流就是描述了页面中接受事件的顺序,在浏览器发展的初期,两大浏览器厂商IE和Netscape互掐,出现了一个坑爹的情况,那就是他们对事件流的解释出现了两中截然相反的定义。也就是我们所熟悉的:IE的事件冒泡,Netscape的事件捕获。先来一张图,简要的看下结构:

1、事件冒泡

事件冒泡即事件最开始由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播至最不具体的节点(文档)。拿上面的图来说明,就是当点击text部分时,先由text处的元素接收,然后逐级传播至window,即执行6-7-8-9-的过程。

2、事件捕获

事件捕获即事件最早由不太具体的节点接收,而最具体的节点最后接收到事件。同理,在上面的模型中,就是点击text部分时,先由window接收,然后逐级传播至text元素,即执行1-2-3-4-5的过程。

具体在代码中怎样表现呢?后面给出!

三、Javascript事件处理程序的3种方式

产生了事件,我们就要去处理他,Javascript事件处理程序主要有3种方式:

1、HTML事件处理程序

即我们直接在HTML代码中添加事件处理程序,如下面这段代码:

JavaScript事件处理的方式(三种)

从上面的代码中我们可以看出,事件处理是直接嵌套在元素里头的,这样有一个毛病:就是html代码和js的耦合性太强,如果哪一天想要改变js中showmsg,那么不但要再js中修改,还需要到html中修改,一两处的修改我们能接受,但是当你的代码达到万行级别的时候,修改起来就需要劳民伤财了,所以,这个方式我们并不推荐使用。

2、DOM0级事件处理程序

即为指定对象添加事件处理,看下面的一段代码:

从上面的代码中,我们能看出,相对于HTML事件处理程序,DOM0级事件,html代码和js代码的耦合性已经大大降低。但是,聪明的程序员还是不太满足,期望寻找更简便的处理方式,下面来看第三种处理方法。

3、DOM2级事件处理程序

DOM2也是对特定的对象添加事件处理程序,但是主要涉及到两个方法,用于处理指定和删除事件处理程序的操作:addEventListener()和 removeEventListener()。它们都接收三个参数:要处理的事件名、作为事件处理程序的函数和一个布尔值(是否在捕获阶段处理事件),看下面的一段代码:

这里我们可以看到,在添加删除事件处理的时候,最后一种方法更直接,也最简便。但是马海祥提醒大家需要注意的是,在删除事件处理的时候,传入的参数一定要跟之前的参数一致,否则删除会失效!

四、事件冒泡和事件捕获的流程与区别

说到这里,再给大家来一点代码来说明下事件冒泡和事件捕获的流程,同时也让大家能看出二者的区别:

运行上面的代码,点击子元素的时候,我们会发现,执行的先后顺序是:父节点捕获--子节点捕获--子节点冒泡--父节点冒泡。从这个例子中,大家也就明白了,另外,DOM2级事件规定事件包括三个阶段:

1、事件捕获阶段;

2、处于目标阶段;

3、事件冒泡阶段。

首先是捕获,然后处于目标阶段(即来到事件的发出位置),最后才是冒泡,不科学的是,居然木有DOM1级事件处理程序,大家注意下,别闹出笑话了!

五、补充

1. IE事件处理程序也对应有两个方法:attachEvent()添加事件,detachEvent()删除事件,这两个方法接收相同的两个参数:事件处理程序名称与事处理函数。这里为什么没有布尔值呢?因为ie8以及更早的版本只支持事件冒泡,所以最后一个参数默认的相当于false来处理!(支持IE事件处理程序的浏览器有IE,opera)。

2. 事件对象是用来记录一些事件发生时的相关信息的对象,但事件对象只有事件发生时才会产生,并且只能是事件处理函数内部访问,在所有事件处理函数运行结束后,事件对象就被销毁!

以上所述是小编给大家介绍的JavaScript事件处理的方式(三种),希望对大家有所帮助!

JS中使用apply、bind实现为函数或者类传入动态个数的参数 为纪念年没写blog,第一篇博文就以这样一个有趣的窍门开始吧-___-在ES5中,当我们调用一个函数时,如果要传入的参数是根据其他函数或条件判断生成

AngularJS实现textarea记录只能输入规定数量的字符并显示 AngularJS是一个MV*框架,最适于开发客户端的单页面应用。它不是个功能库,而是用来开发动态网页的框架。它专注于扩展HTML的功能,提供动态数据绑定

Bootstrap表单组件教程详解 表单常见的元素主要包括:文本输入框、下拉选择框、单选框、复选框、文本域、按钮等。下面是不同的bootstrap版本:LESS:forms.lessSASS:_forms.scssbootstrap仅

标签: JavaScript事件处理的方式(三种)

本文链接地址:https://www.jiuchutong.com/biancheng/373536.html 转载请保留说明!

上一篇:Bootstrap每天必学之工具提示(Tooltip)插件(bootstrap怎么学)

下一篇:Javascript 基础---Ajax入门必看(javascript基础编程)

  • 平价转让股权如何做
  • 没房分手的多吗
  • 残疾人就业保障金会计分录怎么做
  • 股东参与经营可以分红吗
  • 小规模商贸公司没有进项可以开发票吗?
  • 豆粕是农产品初加工,企业所得税免税
  • 全资子公司的利润有多少
  • 公司购买的五金工具报销怎么做
  • 个人劳务费发票可以委托其他人去开吗
  • 过了征期还能报税吗
  • 有单位购买我公司开发的房产作为“投资性房地产”,该单位需要缴纳房产税吗?
  • 选择纳税人身份考虑的因素
  • 货运发票与运输发票的区别
  • 农产品购货发票
  • 资本性支出计算公式为什么加折旧
  • 无票收入科目
  • win7对话框文本框在哪里
  • iTunesHelper.exe是什么进程?iTunesHelper.exe系统错误怎么解决?
  • 键盘灯无法开启
  • php tars
  • 电脑连上WiFi上不了网怎么办?
  • linux系统之间拷贝文件命令
  • 固定资产报废后的处理程序
  • 待安置期间生活补助费多少钱
  • 出口退税需要提供什么
  • 申报个体经营所得税款所属期怎么填
  • 原生js获取document
  • 计提租金怎么做会计分录
  • 企业增值税发票税率是多少
  • 已付款未开票怎么做账
  • 玩转mongodb4.0从入门到实践
  • 个税系统中的离职怎么填
  • 营改增后房屋租赁税变化
  • Windows下MySQL 5.6安装及配置详细图解(大图版)
  • 职工给单位造成损失可以申请仲裁吗
  • 小规模纳税人开专票需要交税吗
  • 预付发票能入账吗
  • 坏账损失属于营业成本吗
  • 单位食堂用餐免费的账务处理
  • 开具成品油发票时注意事项是?
  • 公司与公司之间合作协议
  • 资产减值准备怎么理解
  • 汇算清缴缴纳的所得税怎么做账
  • 支付银行贷款利息的会计处理
  • 以前年度长期股权投资漏记调整
  • 银行存款的收付应严格执行()的规定
  • 无发票临时工劳务费账务处理
  • 工人的工资占企业的比例
  • 买相机送肩带吗
  • mysql索引优化是什么意思
  • sql server本地服务器地址如何查看
  • vista server
  • linux中链接
  • win7链接联机id
  • DWHeartbeatMonitor.exe进程是什么意思 DWHeartbeatMonitor是安全的进程吗
  • win7旗舰版系统怎么样
  • windows7如何关闭夜间模式
  • window8.1下载
  • win10系统中怎么安装安卓应用
  • 内存使用过低
  • 怎样设置ie8
  • 开启win10
  • win7 64位旗舰版电脑如何取消网页自动保存密码?win7取消自动保存网页密码的方法
  • ContentProvider之通过ContentResolver获取图像、视频、音频举例
  • cocos2dx schedule
  • Unity3D游戏开发(第2版)
  • unity3d特效教程
  • js获取当前点击事件的节点
  • android上吹一吹功能的实现代码
  • unity c+
  • 理解的英文
  • jquery iframe写入内容
  • jquery实现搜索功能
  • 运满满订单取消技术服务费退还吗
  • 税控系统技术维护费抵税怎么申报
  • 百旺税控盘怎么清卡
  • 如何连续打印单据
  • 在监狱要花钱吗
  • 佛山顺德人才房申请条件
  • 南京市高新园区
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设