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 相关文章推荐
编写跨浏览器的javascript代码必备[js多浏览器兼容写法]
Oct 29 Javascript
原生JS绑定滑轮滚动事件兼容常见浏览器
Jun 30 Javascript
基于javascript实现图片懒加载
Jan 05 Javascript
jQuery计算文本框字数及限制文本框字数的方法
Mar 01 Javascript
js验证真实姓名与身份证号,手机号的简单实例
Jul 18 Javascript
AngularJS 自定义指令详解及示例代码
Aug 17 Javascript
jQuery选择器中的特殊符号处理方法
Sep 08 jQuery
使用vuex缓存数据并优化自己的vuex-cache
May 30 Javascript
微信小程序拼接图片链接无底洞深入探究
Sep 03 Javascript
uni-app 支持多端第三方地图定位的方法
Jan 03 Javascript
JS实现网页端猜数字小游戏
Mar 06 Javascript
js实现mp3录音通过websocket实时传送+简易波形图效果
Jun 12 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 地区分类排序算法
2013/07/01 PHP
php Imagick获取图片RGB颜色值
2014/07/28 PHP
smarty模板引擎从php中获取数据的方法
2015/01/22 PHP
关于PHP内置的字符串处理函数详解
2017/02/04 PHP
php获取目录中所有文件名及判断文件与目录的简单方法
2017/03/04 PHP
PHP程序员学习使用Swoole的理由
2018/06/24 PHP
Laravel find in set排序实例
2019/10/09 PHP
详解phpstorm2020最新破解方法
2020/09/17 PHP
ASP.NET jQuery 实例12 通过使用jQuery validation插件简单实现用户注册页面验证功能
2012/02/03 Javascript
javascript定义变量时带var与不带var的区别分析
2015/01/12 Javascript
JavaScript实现更改网页背景与字体颜色的方法
2015/02/02 Javascript
根据user-agent判断蜘蛛代码黑帽跳转代码(js版与php版本)
2015/09/14 Javascript
js实现刷新页面后回到记录时滚动条的位置【两种方案可选】
2016/12/12 Javascript
JSON键值对序列化和反序列化解析
2017/01/24 Javascript
AngularJS表格样式简单设置方法示例
2017/03/03 Javascript
js遍历添加栏目类添加css 再点击其它删除css【推荐】
2018/06/12 Javascript
Node.js中的不安全跳转如何防御详解
2018/10/21 Javascript
jquery 键盘事件 keypress() keydown() keyup()用法总结
2019/10/23 jQuery
mpvue微信小程序开发之实现一个弹幕评论
2019/11/24 Javascript
使用python Django做网页
2013/11/04 Python
python绘制立方体的方法
2018/07/02 Python
Python玩转PDF的各种骚操作
2019/05/06 Python
pandas实现将dataframe满足某一条件的值选出
2019/06/12 Python
PyCharm刷新项目(文件)目录的实现
2020/02/14 Python
浅谈numpy中函数resize与reshape,ravel与flatten的区别
2020/06/18 Python
Python函数递归调用实现原理实例解析
2020/08/11 Python
医务人员竞聘职务自我评价分享
2013/11/08 职场文书
三年大学生活自我鉴定
2014/01/21 职场文书
护士岗位职责
2014/02/16 职场文书
环保倡议书范文
2014/05/12 职场文书
优秀教师先进个人事迹材料
2014/08/31 职场文书
2015年仓库管理员工作总结
2015/04/21 职场文书
单独二胎证明
2015/06/24 职场文书
六一文艺汇演主持词
2015/06/30 职场文书
《艾尔登法环》1.03.3补丁上线 碎星伤害调整
2022/04/07 其他游戏