> 웹 프론트엔드 > JS 튜토리얼 > ES6에서 객체 메소드에 화살표 함수를 사용할 수 없는 이유는 무엇입니까?

ES6에서 객체 메소드에 화살표 함수를 사용할 수 없는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2025-01-06 01:54:46
원래의
277명이 탐색했습니다.

Why Can't I Use Arrow Functions for Object Methods in ES6?

ES6 객체의 화살표 함수

ES6에서는 기존 함수 구문과 도입된 단축 메소드 구문을 모두 사용하여 객체의 메소드를 정의할 수 있습니다. 언어:

var chopper = {
    owner: 'Zed',
    getOwner: function() { return this.owner; }
};
로그인 후 복사
var chopper = {
    owner: 'Zed',
    getOwner() { return this.owner; }
};
로그인 후 복사

단, 시도할 때 제한이 발생할 수 있습니다. 객체 메소드에서 화살표 기능을 사용합니다. 예를 들어 다음 구문을 사용하면 오류가 발생합니다.

var chopper = {
    owner: 'John',
    getOwner: () => { return this.owner; }
};
로그인 후 복사

또는

var chopper = {
    owner: 'John',
    getOwner: () => (this.owner)
};
로그인 후 복사

설명

화살표 함수에는 특정 특성이 있습니다. 물건으로 사용하기에 부적합하게 만드는 것 메서드.

  • 어휘 범위: 화살표 함수는 자신이 정의된 객체가 아니라 주변 어휘 범위에서 this 값을 상속합니다. 이는 화살표 함수 내의 이것이 객체 자체가 아니라 객체가 정의된 컨텍스트를 참조한다는 것을 의미합니다.

따라서 ES6 객체 내에서 화살표 함수를 정의할 때 이는 함수 내에서 객체가 생성된 컨텍스트를 참조합니다. 예를 들어 전역 범위 내에서 객체 헬기를 정의하는 경우 getOwner 내부의 이 항목은 헬기 객체가 아닌 전역 범위를 참조합니다.

해결 방법

작성하려면 ES6의 객체 메소드를 사용하려면 전통적인 함수 구문이나 특별히 설계된 단축 메소드 구문을 사용해야 합니다. 개체:

var chopper = {
    owner: 'Zed',
    getOwner: function() {
        return this.owner;
    }
};

// or

var chopper = {
    owner: 'Zed',
    getOwner() {
        return this.owner;
    }
};
로그인 후 복사

이 메서드는 Chopper 개체를 참조하는 올바른 this 바인딩을 사용합니다.

위 내용은 ES6에서 객체 메소드에 화살표 함수를 사용할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿