>웹 프론트엔드 >JS 튜토리얼 >왜 `bind()`가 화살표 함수와 함께 작동하지 않습니까?

왜 `bind()`가 화살표 함수와 함께 작동하지 않습니까?

DDD
DDD원래의
2024-12-09 03:10:17867검색

Why Doesn't `bind()` Work with Arrow Functions?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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