attachEvent和addEventListener 使用方法
Js代码
  • <!DOCTYPE?html?PUBLIC?”-//W3C//DTD?XHTML?1.0?Transitional//EN”?”http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”> ??
  • ??
  • <html?xmlns=”http://www.w3.org/1999/xhtml”> ??
  • <head> ??
  • ????<title>JS</title> ??
  • </head> ??
  • <body> ??
  • ????<input?id=”para”?type=”text”?/> ??
  • ???<script?type=”text/javascript”> ??
  • function?test(){ ??
  • ??alert(“test”); ??
  • } ??
  • ??
  • function?pig(){ ??
  • ??alert(“pig”); ??
  • } ??
  • ??
  • window.onload?=?function(){ ??
  • ?????????var?element?=??document.getElementById(“para”); ??
  • ?????????if(element.addEventListener){??//?firefox??,?w3c ??
  • ????????????????element.addEventListener(“focus”,test,false); ??
  • ????element.addEventListener(“focus”,pig,false); ??
  • ?????????}?else?{???//?ie ??
  • ????element.attachEvent(“onfocus”,test); ??
  • ????element.attachEvent(“onfocus”,pig); ??
  • ?????????} ??
  • } ??
  • </script> ??
  • </body> ??
  • ??
  • </html>??
  • <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <title>JS</title>
    </head>
    <body>
        <input id="para" type="text" />
       <script type="text/javascript">
    function test(){
      alert("test");
    }
    
    function pig(){
      alert("pig");
    }
    
    window.onload = function(){
             var element =  document.getElementById("para");
             if(element.addEventListener){  // firefox  , w3c
                    element.addEventListener("focus",test,false);
        element.addEventListener("focus",pig,false);
             } else {   // ie
        element.attachEvent("onfocus",test);
        element.attachEvent("onfocus",pig);
             }
    }
    </script>
    </body>
    
    </html>

    ****************实例结束**************************

    JS:attachEvent和addEventListener 使用方法
    attachEvent与addEventListener区别
    适应的浏览器版本不同,同时在使用的过程中要注意
    attachEvent方法????????? 按钮onclick
    addEventListener方法??? 按钮click

    两者使用的原理:可对执行的优先级不一样,下面实例讲解如下:
    attachEvent方法,为某一事件附加其它的处理事件。(不支持Mozilla系列)

    addEventListener方法 用于 Mozilla系列

    举例:

    Js代码
  • document.getElementById(“btn”).onclick?=?method1; ??
  • document.getElementById(“btn”).onclick?=?method2; ??
  • document.getElementById(“btn”).onclick?=?method3;如果这样写,那么将会只有medhot3被执行??
  • document.getElementById("btn").onclick = method1;
    document.getElementById("btn").onclick = method2;
    document.getElementById("btn").onclick = method3;如果这样写,那么将会只有medhot3被执行

    写成这样:

    Js代码
  • var?btn1Obj?=?document.getElementById(“btn1″);?//object.attachEvent(event,function); ??
  • btn1Obj.attachEvent(“onclick”,method1); ??
  • btn1Obj.attachEvent(“onclick”,method2); ??
  • btn1Obj.attachEvent(“onclick”,method3);执行顺序为method3->method2->method1??
  • var btn1Obj = document.getElementById("btn1"); //object.attachEvent(event,function);
    btn1Obj.attachEvent("onclick",method1);
    btn1Obj.attachEvent("onclick",method2);
    btn1Obj.attachEvent("onclick",method3);执行顺序为method3->method2->method1

    如果是Mozilla系列,并不支持该方法,需要用到addEventListener var btn1Obj = document.getElementById(“btn1″);
    //element.addEventListener(type,listener,useCapture);
    btn1Obj.addEventListener(“click”,method1,false);
    btn1Obj.addEventListener(“click”,method2,false);
    btn1Obj.addEventListener(“click”,method3,false);执行顺序为method1->method2->method3

    使用实例:

    Js代码
  • 1。?var?el?=?EDITFORM_DOCUMENT.body;? ??
  • //先取得对象,EDITFORM_DOCUMENT实为一个iframe ??
  • if?(el.addEventListener){ ??
  • el.addEventListener(‘click’,?KindDisableMenu,?false); ??
  • }?else?if?(el.attachEvent){ ??
  • el.attachEvent(‘onclick’,?KindDisableMenu); ??
  • }2。?if?(window.addEventListener)?{ ??
  • window.addEventListener(‘load’,?_uCO,?false); ??
  • }?else?if?(window.attachEvent)?{ ??
  • window.attachEvent(‘onload’,?_uCO); ??
  • }???
  • 1。 var el = EDITFORM_DOCUMENT.body;
    //先取得对象,EDITFORM_DOCUMENT实为一个iframe
    if (el.addEventListener){
    el.addEventListener('click', KindDisableMenu, false);
    } else if (el.attachEvent){
    el.attachEvent('onclick', KindDisableMenu);
    }2。 if (window.addEventListener) {
    window.addEventListener('load', _uCO, false);
    } else if (window.attachEvent) {
    window.attachEvent('onload', _uCO);
    }

    detachEvent和removeEventListener

    Js代码
  • detachEvent(‘onclick’,func);//ie下使用删除事件func ??
  • removeEventListener(‘click’,func);//Mozilla下,删除事件func??
  • 自由转载,转载请注明: 转载自WEB开发笔记 www.chhua.com

    本文链接地址: JS事件监听 JS:attachEvent和addEventListener 使用方法 http://www.chhua.com/web-note146

    相关笔记

    更多