>웹 프론트엔드 >JS 튜토리얼 >비동기 콜백 및 함수 인수에서 \'this\' 값을 보존하는 데 JavaScript 바인딩()이 필요한 이유는 무엇입니까?

비동기 콜백 및 함수 인수에서 \'this\' 값을 보존하는 데 JavaScript 바인딩()이 필요한 이유는 무엇입니까?

DDD
DDD원래의
2024-10-25 04:31:29493검색
Why is JavaScript bind() Required for Preserving 'this' Value in Asynchronous Callbacks and Function Arguments?bind()의 필요성

함수를 메서드로 호출하는 경우 객체(예: object.method())인 경우 객체를 올바르게 참조합니다. 그러나 함수가 독립 실행형 함수(예: method())로 호출되면 기본값은 전역 개체로 설정됩니다.

이 문제를 방지하기 위해 바인딩()을 사용하면 다음과 같은 경우 이 값을 수동으로 지정할 수 있습니다. 미래에 함수를 호출합니다. 지정된 개체에 바인딩된 this 값을 사용하여 새 함수를 반환합니다.

예제 2의 솔루션

예제 2에서는 다음을 포함하는 새 함수(storeMyName2)를 생성하는 데 바인딩()이 사용됩니다. 이 참조는 myName에 바인딩되어 있습니다. 이렇게 하면 새 함수가 호출될 때 호출 방법에 관계없이 myName을 참조하게 됩니다.

예제 3과 비교

예제 3에서 storeMyName3은 다음 결과로 설정됩니다. myName.getName()을 직접 호출합니다. 이는 storeMyName3에 반환된 값(단순히 "Tom" 문자열)이 포함되어 있음을 의미합니다. storeMyName, storeMyName2와 같은 기능이 아니어서 이런 개념은 없습니다.

위 내용은 비동기 콜백 및 함수 인수에서 \'this\' 값을 보존하는 데 JavaScript 바인딩()이 필요한 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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