位置: 编程技术 - 正文

学习JavaScript事件流和事件处理程序

编辑:rootadmin

推荐整理分享学习JavaScript事件流和事件处理程序,希望有所帮助,仅作参考,欢迎阅读内容。

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

本文全篇介绍了JavaScript事件流和事件处理程序,分享给大家供大家参考,具体内容如下

一、事件流

事件流描述的是从页面中接收事件的顺序。IE的事件流是事件冒泡流,而Netscape Communicator的事件流是事件捕获流。

二、事件冒泡

即事件开始时由最具体的元素接收,然后逐级向上传播到较为不具体的节点。如:

当点击了页面中的div元素,那么这个click事件会按照如下顺序传播:

div元素 body元素 html元素 document对象

三、事件捕获

事件捕获的思想是最具体的节点应该最后接收到事件。事件捕获的用意在于事件到达目标之前捕获它。

当点击了页面中的div元素,那么这个click事件则会按照如下顺序传播:

document对象 html标签 body标签 div标签

虽然规范要求事件应该从document对象开始传播,但浏览器一般都是从window对象开始捕获事件的。因为老版本浏览器不支持,所以一般都使用事件冒泡。

四、DOM事件流

“DOM2级事件”规定的事件流包括三个阶段:事件捕获阶段、处于目标阶段和事件冒泡阶段。

在DOM事件流中,实际的目标在捕获阶段不会接收事件。就是说在捕获阶段,事件从document到html再到body后就停止了。下一个阶段是“处于目标”阶段,于是事件在div中发生,并在事件处理中被看成是冒泡阶段的一部分。然后,冒泡阶段发生。IE8及更早的版本不支持DOM事件流,浏览器在捕获阶段触发事件对象上的事件,结果就是有两个机会在目标对象上面操作事件。

五、事件处理程序

事件就是用户或浏览器自身执行的某种动作;事件处理程序(或事件侦听器)就是响应某个事件的函数。事件处理程序的名字以“on”开头,如onload、onclick等。

六、HTML事件处理程序

学习JavaScript事件流和事件处理程序

若要在按钮被单击时执行一些js代码,可以这样编写:

注意:不能在其中使用未经转义的HTML语法字符。

也可以调用在页面中其他地方定义的脚本:

事件处理程序中的代码在执行时,有权访问全局作用域中的任何代码。

这样使用会创建一个封装着的元素属性值的函数。这个函数有一个局部变量event,也就是事件对象:

其中,this值等于事件的目标元素,如:

HTML事件处理程序存在众多问题,所以应该使用js指定的事件处理程序

七、DOM0级事件处理程序

要使用js指定事件处理程序,首先必须取得一个要操作的对象的引用。

每个元素都有自己的事件处理程序属性,这些属性通常全部小写,如onclick。如:

使用DOM0级方法指定的事件处理程序被认为是元素的方法。因此,这时候的事件处理程序是在元素的作用域中运行的;也就是this引用当前元素:

以上述这种方式添加的事件处理程序会在事件流的冒泡阶段被处理。

删除通过DOM0级方法指定的事件处理程序:

八、DOM2级事件处理程序

addEventListener()

该方法接收三个参数:要处理的事件名、事件处理程序函数和布尔值;布尔值如果是true,表示在捕获阶段调用事件处理程序;如果是false,表示在冒泡阶段调用事件处理程序。如:

还可以为该按钮添加多个事件处理程序,如:

removeEventListener()

大多数情况下,都是将事件处理程序添加到事件流的冒泡阶段,这样就可以最大限度地兼容各种浏览器。

标签: 学习JavaScript事件流和事件处理程序

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

上一篇:javascript产生随机数方法汇总(javascript产生随机整数随机性强)

下一篇:理解JavaScript事件对象

  • 企业税收收入怎么计算
  • 企业所得税怎么征收几个点
  • 价税分离的公式是什么呀
  • 股东投入款
  • 子公司借钱给母公司的会计处理
  • 增值税申报失败怎么撤销
  • 增值税开票内容货物及应税劳务服务名称都有哪些
  • 农行公户怎么给公户转账
  • 增值税专用发票和普通发票的区别
  • 财务预算是做什么的
  • 按价格从价缴纳增值税
  • 委托企业和受托企业是什么意思
  • 销售亏损原因分析范文
  • 私车公用违规吗
  • 招待客人的场景图
  • 现金不够怎么办
  • 技术开发合同可以开专票吗
  • 电信宽带费发票专票
  • 小规模纳税人出售不动产征收率
  • 代收款项属于收入范围吗
  • 公司招投标卖标书的收入款财务作什么科目?
  • 增值税抵扣联退税多少
  • 固定资产投资成本的回收与实物更新
  • 个人出租住房如何倒算开票金额
  • WIN7系统的镜像文件在哪里
  • 事业单位会计凭证收入怎么记账
  • 开红字发票后再开蓝字发票应如何入账?
  • 微信公众号开发php源码
  • 不动产经营租赁范围
  • PHP daddslashes 使用方法介绍
  • 个体工商户加盟咖啡店
  • 考核工资可以不发吗
  • 财税〔2017〕34号文件中提到的科技型中小企业是指哪种企业?
  • 企业缴纳职工社保比例的规定
  • 房地产企业销售佣金税前扣除
  • laravel enum
  • 小规模纳税人购入货物收到增值税专用发票
  • 残保金计提和缴纳分录
  • phpcms使用教程
  • SQL Server 2016 TempDb里的显著提升
  • dedecms转其他cms
  • 记账王怎么打开以前的账套
  • PostgreSQL管理工具phpPgAdmin入门指南
  • 个人所得税申请退税多久能到账
  • mysql组合
  • 小规模纳税人应纳税额减征额怎么算
  • 外国企业常驻代表机构
  • 结构性存款现金流量表流入里放在哪里
  • 债权投资相关科目
  • 事业单位外出参观培训心得
  • 法人网上变更流程
  • 红字发票信息表在哪里查询
  • 塑料行业税负率是多少
  • 工业企业如何建立税务风险预警体系工作表
  • win8电脑屏幕亮度调节在哪里设置
  • win8.1开机自启项目在哪里
  • win8不能安装软件
  • js explode
  • js实现倒计时60s
  • extjs 3.31 TreeGrid实现静态页面加载json到TreeGrid里面
  • 经过整理的一些成语
  • unity3d怎么做游戏
  • jqgrid设置宽度
  • 解析几何
  • NGUI之UITab Bar的不能将Sprite与SelectedSprite设置成相同的精灵
  • python自动发邮件内容
  • js表单事件有哪些
  • 理解和运用的重要性要站在哪个的视觉去判断
  • 安卓系统引导程序
  • Unity-DF 2048界面
  • jquery easyui开发指南
  • android获取网络数据
  • 浙江银行上班时间查询
  • 关于成品油的吨油换算
  • 金米财税不退款怎么办
  • 大米包装有二道封口线正常吗
  • 国家税务总局2018年61号公告
  • 姓名验证不正确
  • 税务志愿者服务队
  • 审计的起源和发展史
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设