javascript动态添加事件方法详解 || Javascript attachEvent传递参数的办法

    技术2022-05-13  5

    有时候我们需要用javascript动态添加事件,这就涉及到浏览器的兼容性问题,以下是几种常见的方法,我们也常常混合使用。 方法一、setAttribute  var obj = document.getElementById("obj");  obj.setAttribute("onclick", "javascript:alert('测试');");  这里利用 setAttribute 指定 onclick 属性,简单,很好理解,  但是:IE 不支持,IE 并不是不支持 setAttribute 这个函数,而是不支持用 setAttribute 设置某些属性,包括对象属性、集合属性、事件属性,也就是说用 setAttribute 设置 style、onclick、onmouseover 这些属性在 IE 中是行不通的。  方法二、用 attachEvent 和 addEventListener  IE 支持 attachEvent  obj.attachEvent("onclick", Foo);  function Foo()  {  alert("测试");  }  也可写在一起  obj.attachEvent("onclick", function(){alert("测试");});  其它浏览器支持 addEventListener  obj.addEventListener("click", Foo, false);  function Foo()  {  alert("测试");  }  同样也可写在一起  obj.addEventListener("click", function(){alert("测试");}, false);  注意 attachEvent 的事件带 on,如 onclick,而 addEventListener 不带 on,如 click。  顺便说一下 addEventListener 的第三个参数(虽然很少用) useCapture - 如果为 true,则 useCapture 指示用户希望启动捕获。启动捕获后,所有指定类型的事件将在被指派到树中其下面的任何 EventTargets 之前指派给已注册的 EventListener。正在通过树向上 bubbling 的事件将不触发指定的使用捕获的 EventListener。  综合应用  if (window.attachEvent)  {  //IE 的事件代码  }  else  {  //其它浏览器的事件代码  }  方法三、事件 = 函数  例:obj.onclick = Foo;  这在多个浏览器中均支持,这是属于旧的规范(方法二属于 DOM2 的规范),不过由于使用方便,用的场合也比较多。  下面是我的解决办法:  function show(){  alert("Hello, world!!!");  }  obj.setAttribute('onclick',document.all ? eval(function(){show()}) : 'javascript:show()'); 

     

    //添加参数的方法 因为只能传入objcet类型的

    var  newopen  =   function (id,level){   return   function ()  {    opentree(id,level); // 该函数为外部定义的一个执行函数;   }}x.attachEvent( " onclick " ,newopen(id,parseInt(level) + 1 ));y.attachEvent("onclick",newopen(id,parseInt(level)+2));

     

     

    来自网上  只是找的资料分享一下


    最新回复(0)