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

知道这段代码先弹哪个alert么请解释下原因及为什么(ie7

知道这段代码先弹哪个alert么请解释下原因及为什么(ie7

桃花长相依 2018-12-10 10:05:45
<P>&lt;html&gt;<BR>&lt;head&gt;<BR>&lt;script&gt;<BR>&nbsp;var app = function()<BR>&nbsp;{<BR>&nbsp;&nbsp;var obj = document.getElementById("mypp");<BR>&nbsp;&nbsp;obj.attachEvent("onclick",foo1);<BR>&nbsp;&nbsp;obj.attachEvent("onclick",foo2);<BR>&nbsp;}</P> <P>&nbsp;&nbsp;var foo1 = function()<BR>&nbsp;&nbsp;{<BR>&nbsp;&nbsp;alert("clicked!");<BR>&nbsp;&nbsp;};<BR>&nbsp;&nbsp;var foo2 = function()<BR>&nbsp;&nbsp;{<BR>&nbsp;&nbsp;alert("also clicked!");<BR>&nbsp;&nbsp;};<BR>&nbsp;&lt;/script&gt;<BR>&lt;/head&gt;&nbsp;<BR>&nbsp;&lt;body onload="app()"&gt;<BR>&nbsp;&nbsp;&lt;p id="mypp"&gt;test&lt;/p&gt;<BR>&nbsp;&nbsp;&nbsp; &lt;/body&gt;<BR>&lt;/html&gt;</P>
查看完整描述

2 回答

?
慕尼黑5688855

TA贡献1848条经验 获得超2个赞

这一个的确是先执行also clicked!,不过,微软说这个执行顺序是随机的,所以不要依赖这个顺序哪怕你是测试过的! 其实事件附加类似于集合操作,每附加一个事件都会往集合里加一条数据,可以添加,但集合是没有办法保证顺序的,虽然每次的顺序可能差不多,但既然他不肯保证,你也就不能依赖,你试下下面这个就知道了,完全没谱: &lt;html> &lt;head> &lt;script> var app = function() { var obj = document.getElementById("mypp"); obj.attachEvent("onclick",foo1); obj.attachEvent("onclick",foo2); obj.attachEvent("onclick",foo3); obj.attachEvent("onclick",foo4); obj.attachEvent("onclick",foo5); obj.attachEvent("onclick",foo6); obj.attachEvent("onclick",foo7); } var foo1 = function(){alert("1");}; var foo2 = function(){alert("2");}; var foo3 = function(){alert("3");}; var foo4 = function(){alert("4");}; var foo5 = function(){alert("5");}; var foo6 = function(){alert("6");}; var foo7 = function(){alert("7");}; &lt;/script> &lt;/head> &lt;body onload="app()"> &lt;p id="mypp">test&lt;/p> &lt;/body> &lt;/html>


查看完整回答
反对 回复 2018-12-14
?
翻翻过去那场雪

TA贡献2065条经验 获得超14个赞

听某牛人说过,.net中的事件不一定按绑定的顺序发生, 事件激发的顺序不可控, 但是具体的原因未说明, 不知道在js是否也是这样子滴~~~


查看完整回答
反对 回复 2018-12-14
  • 2 回答
  • 0 关注
  • 568 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信