>웹 프론트엔드 >JS 튜토리얼 >`this` 키워드는 다양한 JavaScript 컨텍스트에서 어떻게 작동합니까?

`this` 키워드는 다양한 JavaScript 컨텍스트에서 어떻게 작동합니까?

DDD
DDD원래의
2024-12-28 18:08:18225검색

How Does the `this` Keyword Behave in Different JavaScript Contexts?

객체 리터럴 내: JavaScript에서 수수께끼의 "this" 키워드 공개

객체 리터럴의 범위 내에서 수수께끼의 "this" " 키워드는 JavaScript에서 매우 중요한 의미를 갖습니다. 그 복잡함을 탐구함으로써 우리는 그 정확한 역할과 그 행동을 지배하는 요소를 밝혀냅니다.

1. 바인딩 규칙: 컨텍스트 설명

JavaScript에서 "this"의 바인딩 규칙은 일반적인 기대를 무시하며 다른 많은 OO 언어와 크게 다릅니다. 동작은 코드 내 배치가 아니라 함수 호출 방식에 의해서만 결정됩니다.

2. 이것이 건설 영역을 지배할 때

생성자로 호출되면 "this"가 새로 생성된 객체 내에서 최고 위치를 차지합니다. 새로 생성된 엔터티에 바인딩되어 해당 엔터티의 속성과 메서드를 관리합니다.

3. 객체 메소드: this의 영역

객체 메소드로서 "this"는 이를 호출한 객체를 구현합니다. 그 지배력은 개체의 내부 속성까지 확장되어 개체의 상태에 액세스하고 조작하는 데 없어서는 안 될 도구가 됩니다.

4. 방법적 호출 없이: 전역적 수용

함수나 객체 메소드 외부에서 호출될 때 "this"는 전역 객체를 포용하여 효과적으로 그 대표자가 됩니다. 브라우저에서 이 전역 개체는 "창"으로 나타나 애플리케이션 환경을 제어합니다.

5. 이벤트: A 분산형 this

이벤트 핸들러에서 "this"는 다른 곡조에 맞춰 춤을 춥니다. 이벤트를 트리거한 DOM 요소에 바인딩되어 해당 속성과 메서드에 대한 액세스를 제공합니다. 그러나 DOM에서 분리된 이벤트(예: setTimeout)의 경우 "this"는 전역 객체로 되돌아갑니다.

6. call(), apply(): 이것의 연금술

call() 및 apply() 메소드는 개발자가 원하는 객체에 "this"를 재할당할 수 있도록 하여 메소드 호출에 무한한 유연성을 부여합니다. 이는 호출 체인 및 상속 에뮬레이션을 포함하여 수많은 가능성의 문을 열어줍니다.

7. 바인딩(): 이것에 대한 새로운 끈

현대 JavaScript의 Function.bind()는 "this"를 특정 개체에 명시적으로 바인딩하는 기능을 제공합니다. 이 힘은 자신만의 "this" 컨텍스트로 독립적인 함수를 생성할 수 있는 능력을 부여하여 코드 재사용성과 유지 관리성을 촉진합니다.

8. 엄격 모드: 전역에서 벗어나

엄격 모드는 획기적인 규칙을 도입합니다. 즉, "this"는 메서드로 호출되지 않거나 명시적으로 바인딩되지 않은 경우 전역 개체를 참조하는 것이 금지됩니다. 이러한 변환을 통해 코드 명확성이 향상되고 오류 가능성이 줄어듭니다.

9. 화살표 함수: 이를 재정의

화살표 함수는 "this"의 동작을 혁신합니다. 기존 함수와 달리 선언 시 정적 "this" 바인딩을 설정합니다. 이 바인딩은 상위 개체에서 시작되며 중첩된 함수에서도 변경되지 않습니다.

10. 상속 및 화살표 함수: 이해 상충

화살표 함수는 JavaScript에서 상속에 대한 도전 과제를 제시합니다. 고유한 이 바인딩은 상위 개체에서 속성과 메서드를 상속하는 기능을 방해합니다. 상속을 달성하려면 개발자는 노동 집약적이고 오류가 발생하기 쉬운 작업인 상위 개체의 모든 화살표 기능을 재정의해야 합니다.

요약

"this" 키워드 JavaScript에서 객체 또는 함수와 해당 환경 사이의 통로 역할을 하는 복잡하면서도 필수적인 도구입니다. 바인딩 규칙과 호출 컨텍스트에 따라 제어되는 동작은 JavaScript 코드의 기본 역학을 이해하고 잠재력을 최대한 활용하는 데 중요합니다.

위 내용은 `this` 키워드는 다양한 JavaScript 컨텍스트에서 어떻게 작동합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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