>웹 프론트엔드 >JS 튜토리얼 >자바스크립트 상호작용을 위해 함수 바인딩 코드를 사용하는 방법에 대한 자세한 설명

자바스크립트 상호작용을 위해 함수 바인딩 코드를 사용하는 방법에 대한 자세한 설명

伊谢尔伦
伊谢尔伦원래의
2017-07-20 10:32:141488검색

Function Binding

함수 바인딩은 javascript가 DOM과 상호 작용할 때 자주 사용됩니다. 함수를 정의한 다음 이를 특정 DOM 요소 또는 컬렉션의 이벤트 트리거에 바인딩합니다. 함수 및 이벤트 핸들러는 종종 결합됩니다. 코드 실행 환경을 유지하면서 함수를 변수로 전달하기 위해 함께 사용됩니다.

<button id="btn">按钮</button>
<script>      
  var handler={
    message:"Event handled.",
    handlerFun:function(){
      alert(this.message);
    }
  };
btn.onclick = handler.handlerFun;
</script>

위 코드는 핸들러라는 개체를 생성합니다. handler.handlerFun() 메서드는 DOM 버튼에 대한 이벤트 핸들러로 할당됩니다. 버튼을 누르면 이 함수가 호출되고 경고 상자가 표시됩니다. 경고 상자에는 이벤트 처리됨이 표시되어야 하는 것처럼 보이지만 실제로는 undefiend가 표시됩니다. 문제는 handler.handleClick()의 환경이 저장되지 않아서 이 객체가 결국 핸들러 대신 DOM 버튼을 가리키게 된다는 것입니다

클로저를 사용하여 이 문제를 해결할 수 있습니다

<button id="btn">按钮</button>
<script>      
var handler={
  message:"Event handled.",
  handlerFun:function(){
    alert(this.message);
  }
};
btn.onclick = function(){
  handler.handlerFun();  
}
</script>

물론 이것은 이 시나리오와 관련된 솔루션을 사용하면 여러 개의 클로저를 생성하면 코드를 이해하고 디버그하기가 어려워질 수 있습니다. 더 나은 접근 방식은 함수 바인딩을 사용하는 것입니다.

간단한 바인딩 함수인 바인딩()은 함수와 환경을 가져와 주어진 환경에서 주어진 함수를 호출하는 함수를 반환하고 모든 인수는 그대로 유지합니다. 동적으로 전달합니다.

function bind(fn,context){
  return function(){
    return fn.apply(context,arguments);
  }
}

This 기능은 단순해 보이지만 그 기능은 매우 강력합니다. 클로저는 바인드()에서 생성됩니다. 클로저는 apply()를 사용하여 들어오는 함수를 호출하고 컨텍스트 객체와 매개변수를 apply()에 전달합니다. 반환된 함수가 호출되면 지정된 환경에서 전달된 함수를 실행하고 모든 매개변수를 제공합니다.

<button id="btn">按钮</button>
<script> 
function bind(fn,context){
  return function(){
    return fn.apply(context,arguments);
  }
}     
var handler={
  message:"Event handled.",
  handlerFun:function(){
    alert(this.message);
  }
};
btn.onclick = bind(handler.handlerFun,handler);
</script>

ECMAScript5는 모든 함수에 대한 기본 바인딩() 메서드를 정의하여 작업을 더욱 단순화합니다.

함수 포인터가 값의 형태로 전달되고 함수가 특정 환경에서 실행되어야 하는 한 바인딩된 함수의 효율성이 강조됩니다. 주로 이벤트 핸들러와 setTimeout() 및 setInterval()에서 사용됩니다. 그러나 바인딩된 함수는 일반 함수보다 오버헤드가 더 많고 더 많은 메모리가 필요하며 여러 함수 호출이 약간 느리기 때문에 필요할 때만 사용하는 것이 가장 좋습니다.

위 내용은 자바스크립트 상호작용을 위해 함수 바인딩 코드를 사용하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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