>  기사  >  웹 프론트엔드  >  화살표 함수와 이

화살표 함수와 이

PHPz
PHPz원래의
2024-07-31 01:28:24853검색

Arrow function and this

이 foo.baz()의 결과는 어떻게 될까요??

const foo = {
  bar: 10,
  baz: () => console.log(this.bar),
};


foo.baz();

이 함수는 작동할 것처럼 보이지만 실행하면 결과는 "정의되지 않음"이 됩니다. 왜 그렇습니까?
JavaScript에서는 화살표 함수를 사용할 때 console.log(this.bar) 함수가 전역 변수를 찾습니다. 왜냐하면 “this” 키워드는 주변 개체에 바인딩되지 않고 브라우저 또는 브라우저의 전역 개체(창)에 바인딩되어 있기 때문입니다. node.js 환경.
이 문제를 해결하려면 foo.bar를 사용하거나 코드를 약간 변경하고 다음과 같은 정규 함수 표현식을 사용합니다

 baz: function () {
    console.log(this.bar);
  },

또는 화살표 함수를 사용해야 하는 경우 this.bar와 같은 로컬 변수를 호출하는 대신 객체 이름을 사용하고 foo.bar를 호출할 수 있습니다.

 baz: () => console.log(foo.bar),

이제 출력은 정확하게 10이 됩니다.

위 내용은 화살표 함수와 이의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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