화살표 함수 바인딩: 설명
JavaScript에서 화살표 함수를 사용할 때 개발자는 'this' 바인딩과 관련하여 예상치 못한 동작을 접할 수 있습니다. 일반 함수와 달리 화살표 함수는 어휘 범위를 유지합니다. 즉, 함수가 정의된 환경의 'this' 바인딩을 상속합니다. 따라서 화살표 함수 내에서 'this'를 다시 바인딩하는 것은 불가능합니다.
다음 예를 고려하세요.
var f = () => console.log(this); var o = {'a': 42}; var fBound = f.bind(o); fBound();
이 코드 조각에서는 화살표 함수 'f'를 바인딩하려고 합니다. '.bind()' 메소드를 사용하여 'o' 객체에 연결합니다. 그러나 'fBound'를 호출하면 'o' 대신 전역 'window' 객체가 출력됩니다.
이는 화살표 함수가 어휘적으로 둘러싸는 환경에서 'this' 바인딩을 상속하기 때문입니다. 전역 실행 컨텍스트입니다. 결과적으로 'f()'와 'fBound()'는 항상 전역 'this'를 참조합니다.
이 문제를 방지하려면 바인딩이 필요할 때 일반 함수를 사용하는 것이 좋습니다. 이러한 함수는 새로운 실행 컨텍스트를 생성하여 '.bind()' 메서드를 사용하여 'this' 바인딩을 명시적으로 설정할 수 있게 해줍니다.
위 내용은 JavaScript에서 `bind()`가 화살표 함수와 함께 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!