金沙棋牌官方平台

当前位置:金沙棋牌 > 金沙棋牌官方平台 > 多种方法实现JS动态添加事件,js判断是否为ie的

多种方法实现JS动态添加事件,js判断是否为ie的

来源:http://www.logblo.com 作者:金沙棋牌 时间:2019-09-03 08:28

下面第三种亲测可用

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

方法一、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),例如:

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

复制代码 代码如下:

复制代码 代码如下:

复制代码 代码如下:

if(window.addEventListener){
alert("not ie");
}else if(window.attachEvent){
alert("is ie");
}else{
alert("这种情况发生在不支持DHTML的老版本浏览器(现在一般都支持)")
}

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

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

第二种:

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

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

复制代码 代码如下:

复制代码 代码如下:

复制代码 代码如下:

if(document.all){
alert("IE6");
}else{
alert("not ie");
}

obj.addEventListener("click", Foo, false);
function Foo()
{
alert("测试");
}

obj.addEventListener("click", Foo, false);
function Foo()
{
alert("测试");
}

第三种:

同样也可写在一起obj.addEventListener("click", function(){alert("测试");}, false);
金沙棋牌官方平台,注意 attachEvent 的事件带 on,如 onclick,而 addEventListener 不带 on,如 click。

同样也可写在一起obj.addEventListener("click", function(){alert("测试");}, false);
注意 attachEvent 的事件带 on,如 onclick,而 addEventListener 不带 on,如 click。

复制代码 代码如下:

复制代码 代码如下:

复制代码 代码如下:

var navigatorName = "Microsoft Internet Explorer";
var isIE = false;
if( navigator.appName == navigatorName ){
isIE = true;
alert("ie")
}else{
alert("not ie")
}

考虑兼容性:
if (window.attachEvent)//兼容IE
{
//IE 的事件代码
}
else
{
//其它浏览器的事件代码
}

考虑兼容性:
if (window.attachEvent)//兼容IE
{
//IE 的事件代码
}
else
{
//其它浏览器的事件代码
}

第四种:

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

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

复制代码 代码如下:

版本一:

版本一:

if(! [1,])alert("这是ie浏览器");
   else alert("这不是ie浏览器");

复制代码 代码如下:

复制代码 代码如下:

第一种: 复制代码 代码如下: if(window.addEventListener){ alert("not ie"); }else if(window.attachEvent){ alert("is ie"); }else{ alert("这种情...

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
}
}

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工作组的版本:

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);
});
}
};
}
})();

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 = Foo;
这种绑定事件的方式,兼容主流浏览器,但如果一个元素上添加多次同一事件呢?

复制代码 代码如下:

复制代码 代码如下:

obj.onclick=method1;
obj.onclick=method2;
obj.onclick=method3;

obj.onclick=method1;
obj.onclick=method2;
obj.onclick=method3;

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

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

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

区别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″);
  }
}

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″);
  }
}

var obj = document.getElementById("obj"); obj.setAttribute("onclick", "javascript:alert('测试');"); 但是IE不支持用 setAttribute 设置某些属性,...

您可能感兴趣的文章:

  • JS动态添加元素及绑定事件造成程序重复执行解决
  • javascript实现的动态添加表单元素input,button等(appendChild)
  • js 动态添加元素(div、li、img等)及设置属性的方法
  • 用js动态添加html元素,以及属性的简单实例
  • ASP之处理用Javascript动态添加的表单元素数据的代码
  • JavaScript实现向OL列表内动态添加LI元素的方法
  • JavaScript实现动态添加Form表单元素的方法示例
  • javaScript动态添加Li元素的实例
  • JS中动态添加事件(绑定事件)的代码
  • js动态添加onclick事件可传参数与不传参数
  • JS实现为动态添加的元素增加事件功能示例【基于事件委托】

本文由金沙棋牌发布于金沙棋牌官方平台,转载请注明出处:多种方法实现JS动态添加事件,js判断是否为ie的

关键词: