加入收藏 | 设为首页 | 会员中心 | 我要投稿 核心网 (https://www.hxwgxz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 运营 > 正文

attachEvent和addEventListener方法

发布时间:2018-09-05 04:36:54 所属栏目:运营 来源:站长网
导读:Copy to Clipboard 引用的内容:[www.veryhuo.com]SCRIPT LANGUAGE= Java Script !-- /**************************************************************************** attachEvent使用这个方法,可以给一个事件指派多个处理过程,可是 Mozilla/ Firefox 不
Copy to ClipboardLiehuo.Net Codes引用的内容:[www.veryhuo.com] <SCRIPT LANGUAGE="JavaScript">
<!--
/****************************************************************************
attachEvent使用这个方法,可以给一个事件指派多个处理过程,可是 Mozilla/Firefox 不支持此方法,
但是它支持另一个 addEventListener 方法,它与 attachEvent不同之处在于attachEvent方法中的事
件是已'on'开头的,而addEventListener 是没有'on'的,另外它还有第三个参数,一般指定为 false
****************************************************************************/
function wcj_addEvent(obj,evType,fn){
if(obj.addEventListener){
obj.addEventListener(evType,fn,false);
return true;
}
else if(obj.attachEvent){
var r = obj.attachEvent("on"+evType,fn);
return r;
}else{
return false;
}
}

function init(){
alert("触发我!");
}

wcj_addEvent(window,"load",init);
//-->
</SCRIPT>

 程序中给一个事件指派多个处理过程的话,只要首先判断一下浏览器,然后根据不同的浏览器,选择使用 attachEvent 还是 addEventListener

Copy to ClipboardLiehuo.Net Codes引用的内容:[www.veryhuo.com] if (document.all) {
  //IE浏览器
  window.attachEvent('onload', handler1);
  window.attachEvent('onload', handler2);
}
else {
  //fx浏览器
  window.addEventListener('load', handler1, false);
  window.addEventListener('load', handler2, false);
}

注意:attachEvent 所指派的多个过程的执行顺序是随机的,所以这几个过程之间不要有顺序依赖。另外 attachEvent 和 addEventListener 不仅仅适用于 window 对象,其他的一些对象也支持该方法。

(编辑:核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读