多种方法实现JS动态添加事件


Posted in Javascript onNovember 01, 2013

方法一、setAttribute
var obj = document.getElementById("obj");
obj.setAttribute("onclick", "javascript:alert('测试');");
但是IE不支持用 setAttribute 设置某些属性,包括对象属性、集合属性、事件属性,也就是说用 setAttribute 设置 style、onclick、onmouseover 这些属性在 IE 中是行不通的。

方法二、用 attachEvent 和 addEventListener
IE 支持 attachEvent,object.attachEvent(event,function),例如:

obj.attachEvent("onclick", Foo); 
function Foo() 
{ 
alert("测试"); 
}

或者写成 obj.attachEvent("onclick", function(){alert("测试");});
其它浏览器支持 addEventListener,element.addEventListener(type,listener,useCapture,
obj.addEventListener("click", Foo, false); 
function Foo() 
{ 
alert("测试"); 
}

同样也可写在一起obj.addEventListener("click", function(){alert("测试");}, false);
注意 attachEvent 的事件带 on,如 onclick,而 addEventListener 不带 on,如 click。
考虑兼容性: 
if (window.attachEvent)//兼容IE 
{ 
//IE 的事件代码 
} 
else 
{ 
//其它浏览器的事件代码 
}

上面有两种添加事件的方法,为了同一添加事件的方法,我们不得不再重新写一个通用的添加事件函数:

版本一:

function addEvent(elm, evType, fn, useCapture) { 
if (elm.addEventListener) { 
elm.addEventListener(evType, fn, useCapture);//DOM2.0 
return true; 
} 
else if (elm.attachEvent) { 
var r = elm.attachEvent(‘on‘ + evType, fn);//IE5+ 
return r; 
} 
else { 
elm['on' + evType] = fn;//DOM 0 
} 
}

HTML5工作组的版本:
var addEvent=(function(){ 
if(document.addEventListener){ 
return function(el,type,fn){ 
if(el.length){ 
for(var i=0;i<el.length;i++){ 
addEvent(el[i],type,fn); 
} 
}else{ 
el.addEventListener(type,fn,false); 
} 
}; 
}else{ 
return function(el,type,fn){ 
if(el.length){ 
for(var i=0;i<el.length;i++){ 
addEvent(el[i],type,fn); 
} 
}else{ 
el.attachEvent(‘on‘+type,function(){ 
return fn.call(el,window.event); 
}); 
} 
}; 
} 
})();

方法三、事件 = 函数
例:obj.onclick = Foo;
这种绑定事件的方式,兼容主流浏览器,但如果一个元素上添加多次同一事件呢?
obj.onclick=method1; 
obj.onclick=method2; 
obj.onclick=method3;

如果这样写,那么只有最后绑定的事件,这里是method3会被执行,此时应该用方法二的方法进行事件的绑定

区别IE6、IE7、IE8之间的方法:

var isIE=!!window.ActiveXObject; 
var isIE6=isIE&&!window.XMLHttpRequest; 
var isIE8=isIE&&!!document.documentMode; 
var isIE7=isIE&&!isIE6&&!isIE8; 
if (isIE){ 
if (isIE6){ 


alert(”ie6″); 

}else if (isIE8){ 


alert(”ie8″); 

}else if (isIE7){ 


alert(”ie7″); 

} 
}
Javascript 相关文章推荐
jquery简单体验
Jan 10 Javascript
GreyBox技术总结(转)
Nov 23 Javascript
jquery $.getJSON()跨域请求
Dec 21 Javascript
JavaScript对数字的判断与处理实例分析
Feb 02 Javascript
浅谈javascript控制HTML5的全屏操控,浏览器兼容的问题
Oct 10 Javascript
JS比较两个数值的大小实例
Nov 25 Javascript
详解vue嵌套路由-params传递参数
May 23 Javascript
Vue的路由动态重定向和导航守卫实例
Mar 17 Javascript
Java设计中的Builder模式的介绍
Mar 22 Javascript
微信小程序购物车、父子组件传值及calc的注意事项总结
Nov 14 Javascript
vue实现微信二次分享以及自定义分享的示例
Mar 20 Javascript
关于vue组件事件属性穿透详解
Oct 28 Javascript
基于jquery插件实现常见的幻灯片效果
Nov 01 #Javascript
jQuery Mobile 导航栏代码
Nov 01 #Javascript
js将json格式内容转换成对象的方法
Nov 01 #Javascript
JS实现切换标签页效果实例代码
Nov 01 #Javascript
Javascript delete 引用类型对象
Nov 01 #Javascript
理解Javascript闭包
Nov 01 #Javascript
Javascript 命名空间模式
Nov 01 #Javascript
You might like
php 404错误页面实现代码
2009/06/22 PHP
php的zip解压缩类pclzip使用示例
2014/03/14 PHP
PHP实现的CURL非阻塞调用类
2018/07/26 PHP
Laravel创建数据库表结构的例子
2019/10/09 PHP
php多进程并发编程防止出现僵尸进程的方法分析
2020/02/28 PHP
JavaScript 轻松搞定快捷留言功能 只需一行代码
2010/04/01 Javascript
javascript函数中的arguments参数
2010/08/01 Javascript
基于jquery的内容循环滚动小模块(仿新浪微博未登录首页滚动微博显示)
2011/03/28 Javascript
原生Js实现元素渐隐/渐现(原理为修改元素的css透明度)
2013/06/24 Javascript
juery框架写的弹窗效果适合新手
2013/11/27 Javascript
For循环中分号隔开的3部分的执行顺序探讨
2014/05/27 Javascript
页面内容排序插件jSort使用方法
2015/10/10 Javascript
JS获取IMG图片高宽的简单实例
2016/05/17 Javascript
javascript 动态样式添加的简单实现
2016/10/11 Javascript
JS常用加密编码与算法实例总结
2016/12/22 Javascript
JS设计模式之数据访问对象模式的实例讲解
2017/09/30 Javascript
angular中子控制器向父控制器传值的实例
2018/10/08 Javascript
详解vue-cli+es6引入es5写的js(两种方法)
2019/04/19 Javascript
python实现多线程暴力破解登陆路由器功能代码分享
2015/01/04 Python
Python3连接MySQL(pymysql)模拟转账实现代码
2016/05/24 Python
Python字符编码判断方法分析
2016/07/01 Python
Python数据结构与算法之链表定义与用法实例详解【单链表、循环链表】
2017/09/28 Python
50行Python代码实现人脸检测功能
2018/01/23 Python
如何利用Anaconda配置简单的Python环境
2019/06/24 Python
讲解Python3中NumPy数组寻找特定元素下标的两种方法
2019/08/04 Python
Python产生一个数值范围内的不重复的随机数的实现方法
2019/08/21 Python
面向对象学习之pygame坦克大战
2019/09/11 Python
python时间日期操作方法实例小结
2020/02/06 Python
Python定义函数实现累计求和操作
2020/05/03 Python
pytorch 多分类问题,计算百分比操作
2020/07/09 Python
诉讼代理人授权委托书
2014/04/08 职场文书
综合测评个人总结
2015/03/03 职场文书
社区扶贫帮困工作总结
2015/05/20 职场文书
详解Oracle块修改跟踪功能
2021/11/07 Oracle
鲲鹏 CentOS 7 安装Python3.7
2022/05/11 Servers
SpringBoot项目部署到阿里云服务器的实现步骤
2022/06/28 Java/Android