> 웹 프론트엔드 > JS 튜토리얼 > 언제, 왜 'this'를 사용해야 합니까? JavaScript 개체 변수에서?

언제, 왜 'this'를 사용해야 합니까? JavaScript 개체 변수에서?

Linda Hamilton
풀어 주다: 2024-12-31 08:38:17
원래의
257명이 탐색했습니다.

When and Why Do You Need to Use

"이것"을 사용합니다. Javascript 객체 변수

Javascript에서는 C와 달리 변수 앞에 "this"가 명시적으로 붙어야 합니다. 자신이 속한 개체를 참조합니다. 이것이 두 언어 간의 객체 지향 프로그래밍의 주요 차이점입니다.

Javascript의 "this" 키워드는 함수가 호출되는 객체인 현재 컨텍스트를 나타냅니다. "this." 없이 변수를 선언하면 해당 함수 범위 내에서 지역 변수가 됩니다. 함수 내에서 개체의 속성에 액세스하려면 "this"를 사용해야 합니다. 그 뒤에 속성 이름이 옵니다.

다음 코드를 고려하세요.

function foo() {
    bar = 0; // This creates a local variable
    this.getBar = function() { return bar; } // This creates a privileged method
}
로그인 후 복사

이 코드에서 "bar"는 "foo" 함수 내의 지역 변수이고 "getBar"는 지역 변수에 접근할 수 있는 권한 있는 메서드입니다. "this."를 사용하지 않으면 "getBar"는 "bar"에 액세스할 수 없습니다.

"this"를 사용하는 접근 방식입니다. 객체 메소드 내에서 액세스하려는 모든 변수에 필요합니다. 그러나 Javascript를 사용하면 인스턴스 객체 대신 프로토타입 객체에 메서드를 정의할 수 있습니다. 프로토타입에 정의된 메서드는 해당 개체의 모든 인스턴스에 상속됩니다. 이 경우 "this"를 사용하지 않아도 됩니다. 그 방법들에 대해서는. 예는 다음과 같습니다.

function Foo() {
    this.bar = 0;
}
Foo.prototype.getBar = function() { return this.bar; }
로그인 후 복사

이 코드에서 "getBar"는 프로토타입에 정의되어 있으므로 "Foo"의 인스턴스는 이 메서드를 상속하고 "this" 접두사 없이 "bar"에 액세스할 수 있습니다.

간단히 말하면 "이것"을 사용하는 것입니다. 인스턴스 객체 내부에 정의된 함수/메서드 내에서 객체 속성에 액세스하는 데 필수적입니다. 하지만 대신 프로토타입에 메서드를 정의하면 이를 방지할 수 있습니다.

위 내용은 언제, 왜 'this'를 사용해야 합니까? JavaScript 개체 변수에서?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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