JavaScript事件学习小结(三)js事件对象


Posted in Javascript onJune 09, 2016

相关阅读:

JavaScript事件学习小结(五)js中事件类型之鼠标事件

一、事件对象

1、认识事件对象

事件在浏览器中是以对象的形式存在的,即event。触发一个事件,就会产生一个事件对象event,该对象包含着所有与事件有关的信息。包括导致事件的元素、事件的类型以及其他与特定事件相关的信息。

例如:鼠标操作产生的event中会包含鼠标位置的信息;键盘操作产生的event中会包含与按下的键有关的信息。

所有浏览器都支持event对象,但支持方式不同,在DOM中event对象必须作为唯一的参数传给事件处理函数,在IE中event是window对象的一个属性。

2、html事件处理程序中event

<input id="btn" type="button" value="click" onclick=" console.log('html事件处理程序'+event.type)"/>

这样会创建一个包含局部变量event的函数。可通过event直接访问事件对象。

3、DOM中的事件对象

DOM0级和DOM2级事件处理程序都会把event作为参数传入。

<body>
<input id="btn" type="button" value="click"/>
<script>
var btn=document.getElementById("btn");
btn.onclick=function(event){
console.log("DOM0 & click");
console.log(event.type); //click
}
btn.addEventListener("click", function (event) {
console.log("DOM2 & click");
console.log(event.type); //click
},false);
</script>
</body>

4、IE中的事件对象

第一种情况: 通过DOM0级方法添加事件处理程序时,event对象作为window对象的一个属性存在。

<body>
<input id="btn" type="button" value="click"/>
<script>
var btn=document.getElementById("btn");
btn.onclick= function () {
var event=window.event;
console.log(event.type); //click
}
</script>
</body>

第二种情况:通过attachEvent()添加的事件处理程序,event对象作为参数传入。

<body>
<input id="btn" type="button" value="click"/>
<script>
var btn=document.getElementById("btn");
btn.attachEvent("onclick", function (type) {
console.log(event.type); //click
})
</script>
</body>

但是我有两个地方不懂。

1、通过DOM0级方法添加的事件处理程序中同样可以传入一个event参数,它的type和window.event.type一样,但是传入的event参数却和window.event不一样,为什么?

btn.onclick= function (event) {
var event1=window.event;
console.log('event1.type='+event1.type); //event1.type=click
console.log('event.type='+event.type); //event.type=click
console.log('event1==event?'+(event==event1)); //event1==event?false
}

2、通过attachEvent添加的事件处理程序中传入的event和window.event是不一样的,为什么?

<body>
<input id="btn" type="button" value="click"/>
<script>
var btn=document.getElementById("btn");
btn.attachEvent("onclick", function (type) {
console.log(event.type); //click
console.log("event==window.event?"+(event==window.event)); //event==window.event?false
})
</script>
</body>

以上所述是小编给大家介绍的JavaScript事件学习小结(三)js事件对象的相关知识,希望对大家有所帮助,如果大家想了解更多内容敬请关注三水点靠木网站!

Javascript 相关文章推荐
JavaScript iframe的相互操作浅析
Oct 14 Javascript
网页禁用右键实现代码(JavaScript代码)
Oct 29 Javascript
网页整体变灰白色(兼容各浏览器)实例
Apr 21 Javascript
JavaScript实现判断图片是否加载完成的3种方法整理
Mar 13 Javascript
在node中如何使用 ES6
Apr 22 Javascript
jQuery修改DOM结构_动力节点Java学院整理
Jul 05 jQuery
Angularjs中的$apply及优化使用详解
Jul 02 Javascript
纯javascript前端实现base64图片下载(兼容IE10+)
Sep 14 Javascript
qrcode生成二维码微信长按无法识别问题的解决
Apr 04 Javascript
简单了解JS打开url的方法
Feb 21 Javascript
vue npm install 安装某个指定的版本操作
Aug 11 Javascript
jQuery+ajax实现用户登录验证
Sep 13 jQuery
javaScript事件学习小结(四)event的公共成员(属性和方法)
Jun 09 #Javascript
JavaScript事件学习小结(一)事件流
Jun 09 #Javascript
JavaScript事件学习小结(五)js中事件类型之鼠标事件
Jun 09 #Javascript
基于JS如何实现类似QQ好友头像hover时显示资料卡的效果(推荐)
Jun 09 #Javascript
JS实现星星评分功能实例代码(两种方法)
Jun 09 #Javascript
Node.js中npm常用命令大全
Jun 09 #Javascript
jQuery EasyUI框架中的Datagrid数据表格组件结构详解
Jun 09 #Javascript
You might like
Dedecms V3.1 生成HTML速度的优化办法
2007/03/18 PHP
示例详解Laravel的注册重构
2016/08/14 PHP
PHP 配置后台登录以及模板引入
2017/01/24 PHP
php获取今日开始时间和结束时间的方法
2017/02/27 PHP
[原创]php token使用与验证示例【测试可用】
2017/08/30 PHP
浅谈php调用python文件
2019/03/29 PHP
jQuery获取CSS样式中的颜色值的问题,不同浏览器格式不同的解决办法
2013/05/13 Javascript
jQuery实现等比例缩放大图片让大图片自适应页面布局
2013/10/16 Javascript
用nodejs实现PHP的print_r函数代码
2014/03/14 NodeJs
Yii2使用Bootbox插件实现自定义弹窗
2015/04/02 Javascript
学习JavaScript设计模式之代理模式
2016/01/12 Javascript
深入浅析javascript中的作用域(推荐)
2016/07/19 Javascript
webpack教程之webpack.config.js配置文件
2017/07/05 Javascript
浅谈vue中数据双向绑定的实现原理
2017/09/14 Javascript
微信小程序实现图片上传、删除和预览功能的方法
2017/12/18 Javascript
webpack中使用iconfont字体图标的方法
2018/02/22 Javascript
AngularJS监听ng-repeat渲染完成的方法
2018/03/20 Javascript
vue环形进度条组件实例应用
2018/10/10 Javascript
vue cli3.0 引入eslint 结合vscode使用
2019/05/27 Javascript
layer.prompt输入层的例子
2019/09/24 Javascript
ES6扩展运算符和rest运算符用法实例分析
2020/05/23 Javascript
[19:59]2014DOTA2国际邀请赛 IG战队纪录片
2014/08/07 DOTA
Python 自动安装 Rising 杀毒软件
2009/04/24 Python
Python对数据进行插值和下采样的方法
2018/07/03 Python
一篇文章弄懂Python中所有数组数据类型
2019/06/23 Python
Python装饰器使用你可能不知道的几种姿势
2019/10/25 Python
python 实现矩阵填充0的例子
2019/11/29 Python
Python关于反射的实例代码分享
2020/02/20 Python
用Python开发app后端有优势吗
2020/06/29 Python
Pytest如何使用skip跳过执行测试
2020/08/13 Python
python re的findall和finditer的区别详解
2020/11/15 Python
Mistine官方海外旗舰店:泰国国民彩妆品牌
2016/12/28 全球购物
西班牙在线宠物商店:zooplus.es
2017/02/24 全球购物
Marc O’Polo俄罗斯官方在线商店:德国高端时尚品牌
2019/12/26 全球购物
2015年法务工作总结范文
2015/05/23 职场文书
Java 数组的使用
2022/05/11 Java/Android