JavaScript事件用法浅析


Posted in Javascript onOctober 31, 2016

本文实例讲述了JavaScript事件用法。分享给大家供大家参考,具体如下:

JavaScript通过事件与HTML交互。

事件流

事件流规定了事件的触发规则和顺序。DOM2规定了事件流包括三个阶段:事件捕获 -> 目标触发除 -> 事件冒泡。DOM2规定在事件捕获阶段不应调用事件处理程序,不过各大浏览器都不鸟它。DOM2级的事件处理程序操作函数对:addEventListener和removeEventListener的第三个参数则把这种事变成了DIY,这是一种妥协,同时让初学者认为dom的管理一片混乱。

var btn = document.getElementById("btn");
btn.addEventListener("click",function(){alert(this.id);},false);
document.body.addEventListener("click",function(){alert("body");},false);

更新上述js中addEventListener和removeEventListener中的第三个参数为true,对比为false时的效果,便大约能理解事件流了。

事件

事件是用户或浏览器自身执行的某和动作。

事件处理程序的添加方式

响应事件的函数称为事件处理程序。

指定事件处理程序有以下方式:

HTML特性指定。

如果某个元素支持某个事件,那么就有一个对应的HTML特性,用此特性就可以给其添加事件处理程序 。

<button id="btn" onclick="alert('button click')">button</button>

DOM0级。 将一个函数赋值给一个元素的事件处理程序属性:这是使用js指定事件生理程序的传统方式,至今仍被使用。

var btn = document.getElementById("btn");
btn.onmouseover = function(){
 this.innerHTML="按钮";
};

DOM2级。

通过addEventListener和removeEventListener来管理元素的事件。所有DOM节点都包含这两个方法,它们都包含三个参数,以add为例:

addEventListener(事件名,事件处理函数,是否在事件捕获时执行事件处理程序)

var btn = document.getElementById("btn");
btn.addEventListener("click",function(){alert(this.id);},true);
//注意下面的remove,它完全没有用,这两个匿名函数实际上是不同的对象
btn.removeEventListener("click",function(){alert(this.id);},true);

在上面代码中,指向同一对象的引用被认为是相同的,同样的申明生成的是两个外表相同但是存储在堆上两个不同位置的不同对象。

事件对象

DOM上的事件被触发时,会生成一个事件对象event。无论指定了什么事件处理程序都会传入event对象:准确的地说,event对象是在调用执行函数的执行环境中创建的,根据作用域链的定义,可知它是如何传入的。

var btn = document.getElementById("btn");
var btnClick = function(){
 alert(event.type);
}
btn.onclick = btnClick;//点击btn按钮时,弹出msg:click

event包含丰富的成员,用来控制访问事件,下面是所有事件的共有成员。

target:触发事件的动作直接作用的目标元素。
currentTarget:等于this,事件处理程序作用于的元素。
eventPhase:调用事件处理程序时,所处的事件流中的阶段。1,2,3 三个值分别对应事件流三阶段。
type:事件类型。单击事件对应 String: "click"。

事件类型

事件类型分为以下几类:

UI事件。
焦点事件。
鼠标与滚轮事件。
键盘与文本事件。
复合事件。
变动事件。
HTML5事件。
设备事件。
触摸与手势事件。

PS:关于javascript事件的详细说明可参考本站在线工具:

javascript事件与功能说明大全:
http://tools.3water.com/table/javascript_event

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
prototype Element学习笔记(篇二)
Oct 26 Javascript
jquery 子窗口操作父窗口的代码
Sep 21 Javascript
js淡入淡出焦点图幻灯片效果代码分享
Sep 08 Javascript
javascript实现随机显示星星特效
Jan 28 Javascript
AngularJS  $on、$emit和$broadcast的使用
Sep 05 Javascript
浅谈bootstrap使用中的一些问题以及解决过程
Oct 18 Javascript
如何判断出一个js对象是否一个dom对象
Nov 24 Javascript
微信小程序表单验证功能完整实例
Dec 01 Javascript
vue cli webpack中使用sass的方法
Feb 24 Javascript
vue实现学生录入系统之添加删除功能
Jul 11 Javascript
layui 数据表格+分页+搜索+checkbox+缓存选中项数据的方法
Sep 21 Javascript
手写实现JS中的new
Nov 07 Javascript
js中通过getElementsByName访问name集合对象的方法
Oct 31 #Javascript
JavaScript递归操作实例浅析
Oct 31 #Javascript
在html中引入外部js文件,并调用带参函数的方法
Oct 31 #Javascript
Validform表单验证总结篇
Oct 31 #Javascript
Javascript数组中push方法用法分析
Oct 31 #Javascript
JavaScript中的await/async的作用和用法
Oct 31 #Javascript
使用 jQuery.ajax 上传带文件的表单遇到的问题
Oct 31 #Javascript
You might like
php一些公用函数的集合
2008/03/27 PHP
PHP对文件夹递归执行chmod命令的方法
2015/06/19 PHP
浅析PHP中Session可能会引起并发问题
2015/07/23 PHP
CI框架中类的自动加载问题分析
2016/11/21 PHP
微信小程序 消息推送php服务器验证实例详解
2017/03/30 PHP
thinkPHP框架实现多表查询的方法
2018/06/14 PHP
php多进程并发编程防止出现僵尸进程的方法分析
2020/02/28 PHP
checkbox 复选框不能为空
2009/07/11 Javascript
基于jquery的实现简单的表格中增加或删除下一行
2010/08/01 Javascript
jQuery 拖动层(在可视区域范围内)
2012/05/24 Javascript
jQuery 选择器详解
2015/01/19 Javascript
JS/Jquery判断对象为空的方法
2015/06/11 Javascript
JavaScript实现图片滑动切换的代码示例分享
2016/03/06 Javascript
jQuery实现内容定时切换效果完整实例
2016/04/06 Javascript
扩展bootstrap的modal模态框-动态添加modal框-弹出多个modal框
2017/02/21 Javascript
微信小程序图片自适应支持多图实例详解
2017/06/21 Javascript
webpack打包node.js后端项目的方法
2018/03/10 Javascript
echarts整合多个类似option的方法实例
2018/07/10 Javascript
layui 优化button按钮和弹出框的方法
2018/08/15 Javascript
Vue 自定义标签的src属性不能使用相对路径的解决
2019/09/17 Javascript
原生JavaScript实现贪吃蛇游戏
2020/11/04 Javascript
js回到页面指定位置的三种方式
2020/12/17 Javascript
Vue——解决报错 Computed property &quot;****&quot; was assigned to but it has no setter.
2020/12/19 Vue.js
[11:33]DAC2018 4.5SOLO赛决赛 MidOne vs Paparazi第二场
2018/04/06 DOTA
[43:49]LGD vs CHAOS 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
[01:02:45]完美世界DOTA2联赛 LBZS vs Forest 第三场 11.07
2020/11/09 DOTA
[56:42]完美世界DOTA2联赛循环赛 Matador vs Forest 第二场 11.06
2020/11/06 DOTA
Python中的数学运算操作符使用进阶
2016/06/20 Python
virtualenv实现多个版本Python共存
2017/08/21 Python
Flask框架web开发之零基础入门
2018/12/10 Python
Python XML转Json之XML2Dict的使用方法
2019/01/15 Python
如何实现Django Rest framework版本控制
2019/07/25 Python
html标签之Object和EMBED标签详解
2013/07/04 HTML / CSS
化学教育专业自荐信
2014/07/04 职场文书
乡镇党建工作汇报材料
2014/08/14 职场文书
小学感恩节活动总结
2015/03/24 职场文书