为了账号安全,请及时绑定邮箱和手机立即绑定

关于event 的三个小问题

关于event 的三个小问题

拉莫斯之舞 2018-12-15 15:10:56
问题1关于event 的理解:“event : 事件对象 , 当一个事件发生的时候,和当前这个对象发生的这个事件有关的一些详细的信息都会被临时保存到一个指定地方-event对象,供我们在需要的调用。”教程中说说的"详细的信息都会被临时保存到一个指定地方-event对象"那么这个“临时”时间是多久,还是以其他意思?问题2:写个简单的小例子:    document.onclick=function(ev){                var a=ev||event            /*问题2:第一个ev是不是相当于在函数()中已经申明var里一个叫ev的参数?            然后在标准浏览器情况下把第一个参数默认为的event,就给a赋值了,            在非标准浏览器的ie(6,7)中就ev就是一个申明的变量还没有赋值,为undefined就执行event这个的意思?*/        alert(a)        console.log( typeof a)        for ( var attr in a ){        console.log(attr +"="+ a[attr])    }    } 问题3:     obj.onclick=function(ev){    var a=ev||event    /*问题3:在非标准浏览器的ie(6,7)中event属于全局变量,那么在有多个对象都写过点击事件    ,并且去执行点击的时候event如何记录“事件有关的一些详细的信息”的?    (先点击document,后点击obj)是否在点击obj的时候就把“document记录”的内容替换掉了?*/    a.cancelBubble=true    }
查看完整描述

1 回答

?
慕标琳琳

TA贡献1830条经验 获得超9个赞

问题1:临时是指在函数执行完就会销毁,垃圾回收器会将其清理。
问题2:可以这样理解,但是ie(6,7)是根本没这个参数,所以原本没有声明过程,也没有赋值过程。但是你自己往参数中加了一个参数,所以相当于仅声明,没赋值。
问题3:事件执行时是串行的,因为js单线程,浏览器会保存当前事件所需的event对象;(先点击document,后点击obj)这个可以理解成替换,因为全局变量event是唯一的。

查看完整回答
反对 回复 2019-01-19
  • 1 回答
  • 0 关注
  • 541 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号