HTML 事件(一)

  本篇主要介绍HTML中的事件知识:事件相关术语、DOM事件规范、事件对象。

其他事件文章

1. HTML 事件(一) 事件的介绍

2. HTML 事件(二) 事件的注册与注销

3. HTML 事件(三) 事件流、事件委托

4. HTML 事件(四) 模拟事件操作

 

目录

1. 事件相关术语:介绍事件相关的术语;如:事件类型、事件名称、事件目标等等。

2. DOM事件规范:介绍W3C目前定义的三种DOM事件规范:0、2、3级。

3. 事件类型:介绍了HTML目前的事件类型;如:UIEvent、FocusEvent、MouseEvent、WheelEvent、KeyboardEvent、CompositionEvent。

4. Event 事件对象:表示事件发生时的状态,比如事件在其中发生的元素、键盘按键的状态、鼠标的位置、鼠标按钮的状态等等。

 

1. 事件相关术语

事件可表示为动作。以鼠标为例,移动、点击、悬停都是一种动作,也是事件。

事件类型(event type)表示事件的类型。如:MouseEvent(鼠标事件)、KeyboardEvent(键盘事件)。

事件名称(event name)表示事件的名称。如:click(单击)、dblclick(双击)。

事件目标(event target)表示与发生事件相关的目标对象。

事件处理程序(event handler)指处理事件的函数,即发生事件时,需调用的函数。

事件对象(event object)事件发生时,表事件的状态,比如事件发生的目标、键盘按键的状态、鼠标的位置、鼠标按钮的状态等等。事件触发时,通过参数传递给事件处理程序。

HTML元素中的事件处理程序属性名称是以”on“为前缀,紧跟着事件的名称。如:onclick、onload。

 

2. DOM事件规范

  W3C目前定义了三种DOM事件规范:0、2、3级。

2.1 DOM Level 0 Events

说明:0级DOM事件规范;最初的HTML文档事件规范,由Netscape Navigator 3 或 微软IE 3实现。

规范简介:

①定义了元素的基本事件。如:click、load等;

②以元素的属性方式调用事件。如:<button οnclick=”fn()”></buttom> 或者 htmlElement.οnclick=function(){};

 

2.2  DOM Level 2 Events

说明:2级DOM事件规范;最后更新于2000年11月13日。

地址:https://www.w3.org/TR/DOM-Level-2-Events/

文档地址:https://www.w3.org/TR/DOM-Level-2-Events/DOM2-Events.pdf

规范简介:

①制定事件流,包含三个阶段:事件捕获阶段、处于目标阶段和事件冒泡阶段。

②制定addEventListener()、removeEventListener()、dispatchEvent()等方法对元素事件进行操作。 [IE9之前的版本对应的为:attachEvent()、detachEvent()、fireEvent()];

③制定DocumentEvent接口,包含:createEvent()方法;

④制定Event对象,包含bubbles、cancelable、currentTarget、eventPhase、target、timeStamp、type属性,以及preventDefault()、stopPropagation()方法;

⑤扩展事件模块:UIEvent、MouseEvent、MutationEvent、HTMLEvent。

⑥移除KeyEvents。

 

2.3  DOM Level 3 Events

说明:3级DOM事件规范;最后更新于2015年12月15日。

地址:https://www.w3.org/TR/DOM-Level-3-Events/

主要规范:

①制定事件处理程序的触发排序规则:根据addEventListener()方法的注册顺序依次触发;

②事件流现在包含Window对象;

③修改resize事件为不可冒泡,修改mousemove事件为可取消默认操作;

④Event事件对象添加defaultPrevented属性、stopImmediatePropagation()方法,type属性将区分事件名称的大小写(DOM2不区分);

⑤弃用MutationEvent事件模块,弃用DOMFocusIn和DOMFocusOut事件;

⑥添加新的事件模块:CustomEvent、FocusEvent、KeyboardEvent、CompositionEvent、WheelEvent;UIEvent模块添加:focus、blur事件;MouseEvent模块添加:dblclick事件。

  

3. 事件类型

每一个事件都有归属的事件类型,不同的事件类型具有不同的信息。

3.1 UIEvent Types :用户界面事件类型;当用户与页面上的元素交互时触发

包含事件:load、unload、abort、error、select、resize、scroll。

扩展阅读:https://www.w3.org/TR/DOM-Level-3-Events/#events-uievents

 

3.2 FocusEvent :焦点事件; 当元素获得或失去焦点时触发

包含事件:blur、focus、focusin、focusout。

扩展阅读:https://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent

 

3.3 MouseEvent Types :鼠标事件类型;当鼠标在页面上执行操作时触发

包含事件:click、dblclick、mousedown、mouseenter、mouseleave、mousemove、mouseout、mouseover、mouseup。

扩展阅读:https://www.w3.org/TR/DOM-Level-3-Events/#events-mouseevents

 

3.4 WheelEvent Types :滚轮事件类型;当鼠标滚轮时触发

包含事件:wheel。

扩展阅读:https://www.w3.org/TR/DOM-Level-3-Events/#events-wheelevents

 

3.5 KeyboardEvent Types :键盘事件类型;当键盘在页面上执行操作时触发

包含事件:keydown、keyup、keypress。

扩展阅读:https://www.w3.org/TR/DOM-Level-3-Events/#events-keyboardevents

 

3.6 CompositionEvent Types :复合事件类型;当为IME输入字符时触发

IME:输入法编辑器(Input Method Editor)。

包含事件:compositionstart、compositionupdate、compositionend。

扩展阅读:https://www.w3.org/TR/DOM-Level-3-Events/#events-compositionevents

 

 

4. Event 事件对象

说明:Event 对象表示事件发生时的状态,比如事件在其中发生的元素、键盘按键的状态、鼠标的位置、鼠标按钮的状态等等。

获取方式:事件触发时的第一个参数 或者 事件触发时调用window.event对象。

?
1
2
document.getElementById( 'btn' ).addEventListener( 'click' , function (e){
     console.log(window.event==e); // => true :触发时两者是一样

冒泡事件当子元素触发某一事件时,父元素会触发相同时间(事件为允许冒泡)。

阻止后续处理程序:通过addEventListener()方法可以给元素的同一事件注册多个处理程序,在某个事件中调用了stopImmediatePropagation() 方法后,后面已经注册的处理程序将不会执行。比如,某个元素在click事件上注册了3个函数,在第2个函数上调用了stopImmediatePropagation()方法,第3个函数不会执行。

扩展阅读:https://developer.mozilla.org/en-US/docs/Web/API/Event

4.1 实例属性

属性 readonly boolean bubbles :只读,获取此事件是否冒泡。

属性 readonly boolean cancelable :只读,获取此事件是否可被撤销。true:事件可撤销。可调用preventDefault()取消后续的默认动作。flase:事件不可撤销。

属性 readonly Object currentTarget :只读,获取正在处理此事件的对象,可以为Element、Document对象等等。

属性 readonly boolean defaultPrevented :只读,表示是否已经调用过了preventDefault()。true:已经调用过了preventDefault()方法。

属性 readonly int eventPhase :只读,表示事件的处理阶段:0表示没有正在处理,1表示捕获阶段,2表示目标阶段,3表示冒泡阶段。

属性 readonly Object target :只读,获取触发此事件的对象。

属性 readonly long timeStamp :只读,获取事件创建的时间。eg:console.log(e.timeStamp); // => 1455034313689

属性 readonly string type :只读,获取事件名称(不包含前缀on,如:click)

属性 readonly boolean isTrusted :只读,表示此事件是否由浏览器生成。true:由浏览器生成。false:通过JS创建,如:dispatchEvent()。

 

4.2 实例方法

方法 void preventDefault() :终止事件的后续默认操作(事件要可撤销,即cancelable属性为true)。如:checkbox的click事件,执行这代码,元素不会被勾选和取消勾选。

document.getElementById('ckbox').οnclick=function(e){
    e.preventDefault(); // checkbox不会被勾选和取消勾选
};

方法示例

方法 void stopImmediatePropagation() :阻止当前事件的冒泡行为并且阻止此元素上相同类型事件的后续处理函数

document.body.οnclick=function(e){
    console.log('body-click');                
};

document.getElementById('btn').addEventListener('click', function(e){
    console.log('btn-click-1');
});

document.getElementById('btn').addEventListener('click', function(e){
    console.log('btn-click-2');
    // stopImmediatePropagation()方法将阻止当前事件的冒泡行为并且阻止此元素上相同类型事件的后续处理函数;
    // 将会输出:btn-click-1、btn-click-2
    // 若取消stopImmediatePropagation()方法,将会输出:btn-click-1、btn-click-2、btn-click-3、body-click
    e.stopImmediatePropagation(); 
});

document.getElementById('btn').addEventListener('click', function(e){
    console.log('btn-click-3');
});

方法示例

方法 void stopPropagation() :阻止当前事件的冒泡行为。

document.body.onclick = function (e) {
    console.log('body的click事件');
};
document.getElementById('btn').onclick = function (e) {
    console.log('btn的click事件');
    e.stopPropagation(); // 阻止此事件后续的冒泡行为,原先点击此事件,会触发body的相同类型事件
};

方法详解

 

4.3 currentTarget 与 target 属性的区别

currentTarget :获取正在处理此事件的对象。

target :获取触发此事件的对象。

冒泡阶段时两者的区别: 假设body和Button元素都注册了click事件;当点击Button元素时,body的click事件也会触发,此时在body的click事件内,currentTarget指向body元素,target指向Button元素。

示例:点击Button元素时的显示结果

?
1
2
3
4
5
6
7
8
9
document.body.onclick = function (e) {
     console.log(e.currentTarget); // 指向body元素
     console.log(e.target); // 若是冒泡事件时,指向最开始触发的元素。否则为元素自身。
};
 
document.getElementById( 'btn' ).onclick = function (e) {
     console.log(e.currentTarget);
     console.log(e.target);
};

 

==================================系列文章==========================================

id="webdevroad" src="http://www.cnblogs.com/polk6/archive/2013/05/10/3071327.html" width="0" height="1">本篇文章:5.3 HTML 事件(一) 事件的介绍

Web开发之路系列文章

1.HTML

  1.1 HTML页面源代码布局介绍

  1.2 HTML基础控件介绍

  1.3 iframe 和 frameset 的区别

  1.4 name、id、class 的区别

  1.5 table、form表单标签的介绍以及get和post提交方式

  1.6 HTML kbd键盘元素

  1.7 HTML 鼠标坐标和元素坐标

2.CSS 层叠样式表

  2.1 CSS 选择器及各样式引用方式

  2.2 CSS HTML元素布局及Display属性

  2.3 CSS Float 浮动属性

  2.4 CSS Position 定位属性

3.JavaScript介绍

  3.1 JavaScript var关键字、变量的状态、异常处理、命名规范等介绍

  3.2 JavaScript function函数种类

  3.3 JavaScript Array对象

  3.4 JavaScript Date对象

  3.5 JavaScript Math和Number对象

  3.6 JavaScript String对象

  3.7 JavaScript Object对象

  3.8 JavaScript 自定义对象

  3.9 JavaScript 对象属性介绍

  3.10 JavaScript 开发规范

4.BOM

  4.1 HTML BOM Browser对象

  4.2 HTML 获取屏幕、浏览器、页面的高度宽度

  4.3 HTML URL地址解析

5.DOM

  5.1 HTML DOM 介绍

  5.2 HTML DOM 对象

  5.3 HTML 事件(一) 事件的介绍

  5.4 HTML 事件(二) 事件的注册与注销

  5.5 HTML 事件(三) 事件流与事件委托

  5.6 HTML 事件(四) 模拟事件操作

6.HTML5

  6.1 HTML5 介绍

    6.2 HTML5 语义元素(一)页面结构

    6.3 HTML5 语义元素(二)文本内容

  6.4 HTML5 input元素新的特性

  6.5 HTML5 progress和meter控件 

  6.6 HTML5 sessionStorage会话存储

  6.7 HTML5 localStorage本地存储 

  6.8 HTML5 元素属性介绍

7.ExtJS 4.2

  7.1 ExtJS 4.2 介绍

  7.2 ExtJS 4.2 第一个程序

  7.3 ExtJS 4.2 组件介绍

  7.4 ExtJS 4.2 组件的查找方式

  7.5 ExtJS 4.2 业务开发(一)主页搭建

  7.6 ExtJS 4.2 业务开发(二)数据展示和查询

  7.7 ExtJS 4.2 业务开发(三)数据添加和修改

  7.8 ExtJS 4.2 Grid组件的单元格合并

  7.9 ExtJS 4.2 Date组件扩展:添加清除按钮

  7.10 ExtJS 4.2 评分组件

8.CSS 3

  8.1 CSS3 border-radius边框圆角

  8.2 CSS3 background-image背景图片相关介绍

 

只是记录了自己在学习、使用Web前端内容时的心得和碰到的问题。

参考文献:

1)http://www.w3school.com.cn/

2)《JavaScript权威指南(第六版)》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值