我最近读了一篇关于跨浏览器事件处理的教程……跨浏览器事件处理……
我已经将教程中的一些实践改编为像这样浮动的通用函数......
function isHostMethod(object, property) {
var type = typeof object[property];
return type === "function" || (type === "object" && !! object[property]) || type === "unknown";
}
var events = {
add: (function() {
if (isHostMethod(this, 'addEventListener')) {
return function(element, type, handler) {
element.addEventListener(type, handler, false);
};
} else if (isHostMethod(this, 'attachEvent')) {
return function(element, type, handler) {
element.attachEvent('on' + type, function() {
handler.call(element, window.event);
});
};
} else {
return function(element, type, handler) {
element['on' + type] = handler;
};
}
}()),
remove: (function() {
if (isHostMethod(this, 'removeEventListener')) {
return function(element, type, handler) {
element.removeEventListener(type, handler, false);
};
} else if (isHostMethod(this, 'detachEvent')) {
return function(element, type, handler) {
element.detachEvent('on' + type, function() {
handler.call(element, window.event);
});
};
} else {
return function(element, type, handler) {
element['on' + type] = null;
};
}
}())
};
用法:
var img_wrap = document.getElementById('img_wrap'),
img = img_wrap.getElementsByTagName('img'),
img_amount = img.length;
function do_stuff() {
//
//do stuff - update preloaded percentage, etc.
//
events.remove(this, 'load', do_stuff);
}
for (var i = 0; i < img_amount; i += 1) {
events.add(img[i], 'load', do_stuff);
}
这就是我很好奇...
1. 'isHostMethod' 功能是否必要?
2. 本教程警告内存泄漏,并概述了一个附加函数,以避免它们使用“唯一 ID”作为对每个元素的引用......这还没有被包括在内......也许我正在监督一些事情,但我没有认为在我的情况下这是必要的......或者我应该担心吗?
jsfiddle这里 警告:图像很大,需要一段时间才能下载,大量带宽等。