Javascript 바인딩() 메서드
call() 및 apply()는 수동으로 전달하여 특정 컨텍스트로 함수를 호출하는 데 사용됩니다. 또는 인수를 배열로 제공하는 경우 바인딩() 메서드는 다른 용도로 사용됩니다.
사용 시기 바인딩()
나중에 호출하기 위해 미리 정의된 컨텍스트를 사용하여 새 함수를 생성해야 하는 경우 바인딩() 메서드를 사용해야 합니다. 이는 이벤트 처리 및 비동기 콜백에 특히 유용합니다.
call() 및 apply()
즉시 실행되는 call() 및 apply()와는 다릅니다. 함수, 바인딩()은 새 함수를 반환합니다. 이 새 함수가 실행되면 원래 함수의 컨텍스트가 바인딩된 개체로 설정됩니다.
다음 예를 고려하세요.
var obj = { x: 81, getX: function() { return this.x; } }; // Bind the function to the object 'obj' var boundGetX = obj.getX.bind(obj); // Later, invoke the bound function with the desired context alert(boundGetX());
이 시나리오에서boundGetX 함수는 비동기적으로 호출되거나 콜백에서 호출되는 경우에도 obj 객체의 컨텍스트.
이벤트에서의 사용 처리
이벤트를 처리할 때 특정 개체의 컨텍스트를 유지하려는 것이 일반적입니다. 바인딩()을 사용하면 이벤트 핸들러가 실행될 때 올바른 컨텍스트를 갖도록 할 수 있습니다.
function MyObject(element) { this.elm = element; element.addEventListener('click', this.onClick.bind(this), false); }; MyObject.prototype.onClick = function(e) { // 'this' refers to the MyObject instance // Perform some action... };
onClick 함수를 MyObject 인스턴스에 바인딩하면 클릭 이벤트가 발생할 때 this 키워드가 이벤트 핸들러는 MyObject 인스턴스를 참조합니다.
구현 세부 정보
간단한 구현 바인딩()은 다음과 같습니다.
Function.prototype.bind = function(ctx) { var fn = this; return function() { fn.apply(ctx, arguments); }; };
위 내용은 언제 JavaScript의 바인드() 메소드를 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!