Arrow 함수에서 'this' 바인딩
ES6에 도입된 화살표 함수는 간결한 구문으로 인해 인기를 얻었습니다. 그러나 화살표 기능의 한 가지 제한 사항은 'this'를 다시 바인딩할 수 없다는 것입니다. 일반 함수와 달리 화살표 함수는 정의 시 주변 컨텍스트에서 'this' 바인딩을 상속합니다.
제공된 예에서 화살표 함수:
var f = () => console.log(this);
는 글로벌 범위. 따라서 'this'는 함수를 바인딩하려고 시도하는 'o' 개체가 아니라 전역 창 개체를 나타냅니다.
var fBound = f.bind(o); fBound(); // Logs the window object
이 문제를 해결하려면 화살표 기능을 사용하지 마세요. 대신 일반 함수를 정의하세요.
var f = function() { console.log(this); }.bind(o); f(); // Logs the 'o' object
이 경우 일반 함수가 사용되므로 'this' 바인딩이 'o' 객체로 올바르게 설정되어 바인딩을 다시 할당할 수 있습니다.
위 내용은 왜 `bind()`가 화살표 함수와 함께 작동하지 않습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!