// 작성 Dean Edwards, 2005
// Tino Zijdel, Matthias Miller, Diego Perini의 의견 포함
//http://dean.edwards.name/weblog/2005/10/add- 이벤트/
function addEvent(element, type, handler) {
if (element.addEventListener) {
element.addEventListener(type, handler, false);
} else {
// 각 이벤트 핸들러에 고유 ID 할당
if (!handler.$$guid) handler.$$guid = addEvent.guid ;
// 요소에 대한 이벤트 유형의 해시 테이블을 생성합니다.
if (!element.events) element.events = {};
//각 요소/이벤트 쌍에 대한 이벤트 핸들러의 해시 테이블을 생성합니다.
var 핸들러 = element.events[type];
if (!handlers) {
핸들러 = element.events[type] = {};
// 기존 이벤트 핸들러를 저장합니다(있는 경우)
if (element["on" type]) {
handlers[0] = element["on" type];
}
}
// 해시 테이블에 이벤트 핸들러를 저장합니다.
handlers[handler.$$guid] = handler;
// 모든 작업을 수행하도록 전역 이벤트 핸들러를 할당합니다.
element["on" type] = handleEvent;
}
};
//고유 ID를 생성하는 데 사용되는 카운터
addEvent.guid = 1;
function removeEvent(element, type, handler) {
if (element.removeEventListener) {
element.removeEventListener(type, handler, false);
} else {
//해시 테이블에서 이벤트 핸들러를 삭제합니다
if (element.events && element.events[type]) {
delete element.events[type][handler.$ $안내];
}
}
};
function handleEvent(event) {
var returnValue = true;
// 이벤트 객체 잡기(IE는 전역 이벤트 객체를 사용함)
이벤트 = 이벤트 || fixEvent(((this.ownerDocument || this.document || this).parentWindow || window).event);
// 이벤트 핸들러의 해시 테이블에 대한 참조 가져오기
var 핸들러 = this.events[event.type];
// 각 이벤트 핸들러를 실행합니다.
for (var i in handlers) {
this.$$handleEvent = handlers[i];
if (this.$$handleEvent(event) === false) {
returnValue = false;
}
}
return returnValue;
};
function fixEvent(event) {
// W3C 표준 이벤트 메소드 추가
event.preventDefault = fixEvent.preventDefault;
event.stopPropagation = fixEvent.stopPropagation;
반품 이벤트;
};
fixEvent.preventDefault = function() {
this.returnValue = false;
};
fixEvent.stopPropagation = function() {
this.cancelBubble = true;
};