将事件写在html中就能执行整体事件,写在js里为什么不能执行?

本文探讨了JavaScript中事件处理的不同方式,特别是在HTML与JS分离时如何正确绑定事件。解释了为何直接在HTML标签中绑定事件与在JS代码中绑定事件存在差异,并提供了在不同浏览器下兼容的解决方案。

======================================================
注:本文源代码点此下载
======================================================

将事件写在html中就能执行整体事件,写在js里为什么不能执行?

body>

div id="div1" onclick="fn(event)" style="width:200px; height:200px; background-color:#0cc">

1111

div>

body>

html>

script type="text/javascript">

var odiv = document.getelementbyid("div1")

function fn(event){

alert(event.target.id);

}

//odiv.onclick=function(){fn(event)}为什么我把代码放在这里不能执行,而放在id为div1的html标签内就能执行。

script>

解决方法:

以上代码在火狐里确实不行,原因如下:

odiv.onclick=function(){fn(event)}

这样写,fn(event)的event相当于是实参,而这个event在外面的那个匿名方法里是没有定义的(在ie中是定义了的,就是

window.event这个全局的事件对象),没有定义就是undefined,所以不行。改成

odiv.onclick=function(event){fn(event)} 就可以了

-------------------------------------------------------------------------------------------------------

background-color:#0cc">为什么这样就行呢,因为火狐在处理这个onclick="fn(event)"时,会自动的把这个

代码转化为onclick=function(event){fn(event)} 。在用firebug调试的时候会发现是这样的。

注意:里面的参数一定要是event才行,要不然也会报错。

绿色通道:好文要顶关注我收藏该文与我联系

posted on 2011-09-26 16:41 春雨_yang 阅读(16) 评论(0)编辑 收藏


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值