位置: 编程技术 - 正文

js学习笔记之事件处理模型(js必须掌握的知识点)

编辑:rootadmin

推荐整理分享js学习笔记之事件处理模型(js必须掌握的知识点),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js基础笔记,javascript总结笔记,javascript总结笔记,js基础笔记,js笔记总结,js重要知识点,js必学知识点,js基础笔记,内容如对您有帮助,希望把文章链接给更多的朋友!

在各种浏览器中存在四种事件模型:原始事件模型、标准事件模型、IE事件模型,还有一种Netscape4事件模型,下面具体介绍一下。

1、目前共存在四种事件处理模型分别是:原始事件模型、标准事件模型、IE事件模型,还有一种Netscape4事件模型,但基本可忽略

2、事件处理模型又可以分为基本事件处理和高级事件处理两种,原始事件模型属于基本事件处理,标准事件模型和IE事件模型属于高级事件处理

一、基本事件处理:

基本事件处理主要是指原始事件模型实现的事件处理。其主要分为以下两种:

(1)、作为HTML标签性质的事件处理,比如 <div onmouseover=”var a=1; alert();”>……</div> //在这里,onmouseover只是一个代表,还包含其他很多事件

在这种方式中,赋给onmouseover等事件处理函数的是JS代码串,系统会把这些代码串自动包装在一个匿名函数中。其中可以有this关键字,它指向的是这个标签元素,也可以有event关键字,它表示的是事件发生时的事件对象(用在标准浏览器中)。如<div onmouseover=”f(this,event);”>……</div>

其实我们可以把onmouseover等看成是一个函数,在没给它赋值前,它就是一个空函数。给它赋了js代码后,就相当于往空函数里添加了代码。因为onmouseover等其实是一个函数,所以我们可以显示的调用它,例如 element.onmouseover(),但这样并不会引起mouseover事件的真正发生。

可以给事件函数(即onmoouseover等)返回false来举止默认动作的发生。

函数是运行在定义它的作用域中,因此如果给事件处理函数赋值js代码,就相当于是在这个HTML标签环境中定义了一个函数,这种环境比较特殊,它的高一级的作用域并不是window全局对象环境,在这两者之间还相隔这至少一种作用域环境。而在<script>中定义的函数,它的高一级作用域环境就是window(当然嵌套函数又要另当别论)。所以,在HTML标签中,最好把代码放在一个在<script>中定义的函数里,然后再把这个函数调用赋给事件函数,即<div onmouseover=“function();”>……</div>

(2)、作为javascript属性的事件处理 比如element.onmouseover=function(){……}

注意在这种方式,不能再给事件处理函数赋值js代码串了,而是直接把函数(不是函数调用)赋给它,或是赋一个匿名函数,如 element.onmouseover=function(){……} 或 element.onmouseover=f; f为一个函数,在这里不能加上括号

基本事件处理也会以冒泡的形式向上传播

二、高级事件处理:

高级事件处理只要是指标准事件模型和IE事件模型实现的事件处理。

【概念理解】 事件的传播可分两种:一种是捕获传播,一种是冒泡传播。

捕获传播:即事件从外传到里,每一级都发生了该事件

冒泡传播;即事件从里传到外,每一级都发生了该事件,并不是所有的事件都会冒泡

(1)标准事件模型

标准事件模型既能发生冒泡传播也能发生捕获传播。

【 事件注册函数】

addEventListener() 该方法为特定元素注册事件处理程序,有三个参数,第一个参数是事件名,注意没有前缀on,第二个是处理函数(当然也可以是匿名函数),事件发生时,系统会自动给该函数的第一个参数传入一个Event对象。最后一个参数是布尔值,如果为true,则只用于事件捕获传播阶段,如果为false则只用于事件冒泡传播阶段,一般我们把它设为false

例如:element.addEventListener(“click”,f,false) //其中f为一个函数

f函数可以这样定义:function f(e){……} //其中的参数在事件发生时就代表Event对象

高级事件处理的一大优势是可以给同一个元素注册多个事件处理函数,这些事件函数执行的顺序并不能确定,但一般来说是按注册的先后顺序来执行,如果注册了重复的事件函数,则只有第一个会生效。

removeEventListener() 该方法用来解除事件注册,它的三个参数与addEventListener() 相同

(2)IE事件模型

IE事件模型只支持事件冒泡传播

【 事件注册函数】

attacthEvent() 该方法只有2个参数,一个为事件名,注意有前缀on,第二个为事件处理函数。例如 element.attachEvent(“onclick”,f)

IE事件模型的Event对象并不是作为事件发生时做为参数传入事件处理函数的,IE的Event对象是一个window的全局对象,只有在事件发生时才可以访问。

所以f函数可以这样定义: function f(){var e=window.event;……} //其中e就取得了Event对象

detachEvent() 该方法用来取消事件注册,参数与attacthEvent() 相同

addEventListener() 与attacthEvent() 的一个重要差别是attacthEvent()注册的事件处理函数中的this关键字永远是指向window对象的,而addEventListener() 注册的事件处理函数中的this指向的是发生了事件的元素

(3)、IE与标准事件模型的Event对象比较

IE 事件对象

IE事件对象

标准事件对象

标准事件对象

altKey

true表示按下了ALT键,false表示没有

altKey

true表示按下了ALT键。false表示没有

ctrlKey

js学习笔记之事件处理模型(js必须掌握的知识点)

true表示按下了CTRL键,false表示没有

ctrlKey

true表示按下了CTRL键,false表示没有

shiftKey

true表示按下了SHIFT键,false表示没有

shiftKey

true表示按下了SHIFT键,false表示没有

button

鼠标事件。0表示没有按下鼠标键,1为按下左键,2为按下右键,4为中间键,3为同时按下左右键,5为按下左键和中键,6为按下右键和中键,7为按下左键、中键、右键

button

0为左键,1为中键,2为右键

clientX

事件发生时,鼠标在浏览器窗口(不包含工具栏、滚动条等)的X坐标

clientX

事件发生时,鼠标在浏览器窗口(不包含工具栏、滚动条等)的X坐标

clientY

同上

clientY

同上

screenX

事件发生时,鼠标在整个屏幕上的X坐标

screenX

事件发生时,鼠标在整个屏幕上的X坐标

screenY

同上

screenY

同上

type

事件的名称(如click)

type

事件的名称(如click)

srcElement

引起事件的元素

target

引起事件的元素

keyCode

对于keypress事件,表示按钮的unicode字符,对于keydown和keyup事件则表示按钮的数字代码

charCode

表示按键的Unicode字符

keyCode

表示按键的数字代码

cancelBubble

值为true时将阻止事件继续向上冒泡

stopPropagation

可以调用这个方法来阻止事件继续向上冒泡

cancelBubble

true表示事件冒泡已被取消,false表示没有

returnValue

值为false时将会阻止事件的默认行为

preventDefault()

调用该方法可以阻止事件的默认行为

offsetX

获取事件发生时鼠标相对于引起事件的元素的X坐标,即以引起事件的元素的本身(不用计算padding和margin)的左上角为原点

layerX

当引发事件的元素没有动态定位时,返回鼠标相对于引发事件的元素的最近的一个设置了动态定位的父元素里的X坐标,以其父元素的边框的左上角为原点。 当引发事件的元素设置了动态定位后,则返回鼠标相对于引发事件的元素的X坐标,以该元素边界的左上角为原点。

x

获取鼠标相对于引发事件的元素的最近一个设置了动态定位的父元素的X坐标,以该父元素的边框i的坐上角为原点

标签: js必须掌握的知识点

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

上一篇:深入理解JavaScript中的块级作用域、私有变量与模块模式(深入理解新发展理念,推进供给侧结构性改革)

下一篇:javascript 内置对象及常见API详细介绍(javascript内置对象应用团购)

  • 购销合同印花税按70%
  • 增值税的特点是实行
  • 以前年度什么意思
  • 包装运杂费结转生产成本会计分录
  • 职工教育经费中其他费用包括
  • 长期股权投资审计说明
  • 工业企业会计怎么结转成本
  • 分期收款销售货物 收入确认
  • 电子发票与纸质发票具有同等效力
  • 企业所得税研发费用100%扣除的有哪些企业
  • 设备折旧费用的作用
  • 一般企业和行政事业单位的资产负债表是否一样
  • 印花税申报表如何填写
  • 公司年会增值税专用发票可以抵扣吗?
  • 增值税减除后附加税计算方法
  • 铲车费属于劳务费吗
  • 会计费用涉及哪些科目?
  • 预提费用对应
  • 进口产品需要交税吗
  • 进项税转出如何申报纳税
  • 房地产税开征的利弊分析
  • 个体工商户怎么交社保
  • 基建期增值税如何抵扣
  • 简单介绍linux
  • QuickBooks - QuickBooks是什么进程 有什么用
  • 无形资产原值增加,净值减少的原因
  • php json转对象
  • 出租房屋收取的水电费的税率
  • 在win10中如何设置在开始菜单中显示应用列表
  • 计划成本法和实际成本法区别
  • 用支票购入厂部办公用品2000元,车间办公用品1000元
  • keyemain.exe是什么进程
  • antvl7
  • 收到银行本票的账务处理
  • 以前年度损益调整属于哪类科目
  • chormedriver安装
  • 新会计制度出台的背景
  • 增值税专用发票丢了怎么补救
  • 真菌感染手指甲空了
  • react reducer详解
  • 农产品小规模纳税人
  • 对公收费明细入账计入什么科目
  • [深度学习] 基于切片辅助超推理库SAHI优化小目标识别
  • 外贸出口退税操作流程
  • 企业可以将自己辞退吗
  • 支付宝对公账户怎么转账
  • 新建厂房如何计提折旧费用
  • 不具备独立核算条件的行政单位
  • mongodb数据删除
  • 帝国cms模型
  • 土地增值税是对转让什么并取得收入的单位和个人
  • sqlserver2008r2数据库导出教程
  • 电脑访问另一台电脑访问权限
  • 代扣代缴境外增值税怎么申报
  • 待抵扣进项税在贷方怎么冲掉
  • 承包费会计处理
  • 小规模纳税人什么时候用3%什么时候用5%
  • 燃油费如何做账会计分录
  • 甲企业于2019年3月1日以2000万元取得乙上市公司
  • 支出费用的区别
  • 应计入产品成本的停工损失是
  • 解析sql语句
  • win8链接wi-fi
  • XP系统安装不了QQ
  • windows一键安装
  • sisusbrg.exe - sisusbrg是什么进程 有什么用
  • windows无法预览文件
  • perl常用函数
  • unity3d状态机
  • excel password recovery5.0注册码
  • 《噩梦》
  • 安卓手机自定义ua
  • vue轮播图插件有哪些
  • linux命令统计
  • jquery设置图片路径
  • 一个超简单的纸飞机
  • 收到虚开的增值税专用发票
  • 办公室主任和党支部书记哪个职位高
  • 从国外进口设备需要缴纳增值税吗
  • 应缴纳资源税税额怎么计算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设