>웹 프론트엔드 >JS 튜토리얼 >window.addeventjs 이벤트 기반 함수 모음 addEvent 등 _javascript 기술

window.addeventjs 이벤트 기반 함수 모음 addEvent 등 _javascript 기술

WBOY
WBOY원래의
2016-05-16 19:06:071431검색

// 작성 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;
};

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.