>웹 프론트엔드 >JS 튜토리얼 >JavaScript 이벤트 바인딩, 트리거 및 삭제 샘플 코드에 대한 자세한 설명

JavaScript 이벤트 바인딩, 트리거 및 삭제 샘플 코드에 대한 자세한 설명

伊谢尔伦
伊谢尔伦원래의
2017-07-22 17:20:151710검색

JavaScript는 이벤트 바인딩 및 트리거링은 물론 이벤트 삭제도 요구하는 가장 간단한 이벤트 모델입니다.


var eventModel = {
 list: {},
 bind: function () {
 var args = [].slice.call(arguments),
 type = args[0],
 handlers = args.slice(1);
 if (typeof type === 'string' && handlers.length > 0) {
  for (var i = 0; i < handlers.length; i++) {
  if (typeof handlers[i] === &#39;function&#39;) {
   if (!this.list[type]) {
   this.list[type] = [];
   }
   this.list[type].push(handlers[i]);
  }
  }
 }
 },
 unbind: function () {
 var type = arguments[0],
 handlers = Array.prototype.slice.call(arguments, 1);
 if (typeof type === &#39;string&#39;) {
  if (handlers.length === 0) {
  this.list[type] = [];
  } else {
  for (var i = 0; i < handlers.length; i++) {
   if (typeof handlers[i] === &#39;function&#39; && handlers[i] === this.list[type][i]) {
   this.list[type].splice(i, 1);
   }
  }
  }
 }
 },
 trigger: function () {
 var arguments = [].slice.call(arguments),
 type = arguments[0],
 args = arguments[1] instanceof Array && !arguments[2] ? arguments[1] : arguments.slice(1),
 handlers = this.list[type];
 for (var i = 0; i < handlers.length; i++) {
  handlers[i].apply(this, args.splice(0, handlers[i].length));
 }
 }
};

주로 바인딩(바인딩 이벤트), 언바인드(삭제 이벤트), 트리거(트리거 이벤트)를 구현합니다. 동일한 이벤트 이름에 대해 여러 이벤트 처리 함수를 바인딩할 수 있으며 바인딩된 순서대로 순차적으로 트리거됩니다.

args.splice(0, handlers[i].length) 트리거 시 전달되는 매개변수

이벤트 바인딩 및 트리거링:


eventModel.bind(&#39;myevent1&#39;, function (a) {
 console.log(a); // 1
}, function(b) {
 console.log(b); // 2
}, function(c, d) {
 console.log(c + &#39; + &#39; + d); // a + b
});
eventModel.bind(&#39;myevent1&#39;, function (e) {
 console.log(e); // 50
});
eventModel.trigger(&#39;myevent1&#39;, 1,2,&#39;a&#39;,&#39;b&#39;, 50);

이벤트 삭제:


<button id="bind">bind</button>
<button id="unbind">unbind</button>


var fnX = function () {
 console.log(&#39;fnX&#39;);
}
var fnY = function () {
 console.log(&#39;fnY&#39;);
}
eventModel.bind(&#39;myevent2&#39;, fnX, fnY);
document.getElementById(&#39;unbind&#39;).onclick = function () {
 eventModel.unbind(&#39;myevent2&#39;, fnX); //删除 fnX 后,只剩下 fnY
};
document.getElementById(&#39;bind&#39;).onclick = function () {
 eventModel.trigger(&#39;myevent2&#39;); //输出 fnX fnY
 //在点击unbind后,只输出 fnY
};

위 내용은 JavaScript 이벤트 바인딩, 트리거 및 삭제 샘플 코드에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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