> 웹 프론트엔드 > JS 튜토리얼 > JavaScript의 `this` 키워드 이해하기

JavaScript의 `this` 키워드 이해하기

王林
풀어 주다: 2024-07-16 16:35:40
원래의
804명이 탐색했습니다.

Understanding the `this` Keyword in JavaScript

JavaScript의 this 키워드는 초보 개발자에게 가장 혼란스러운 개념 중 하나일 수 있습니다. 그 값은 사용되는 위치에 따라 달라질 수 있으므로 다양한 상황에서 동작을 이해하는 것이 중요합니다. 이 기사에서는 다양한 시나리오에서의 사용법을 탐색하여 this 키워드에 대한 이해를 돕습니다.

이게 뭔가요?

자바스크립트에서는 함수가 실행되는 컨텍스트를 나타냅니다. 객체 자체 내에서 객체의 속성과 메서드에 액세스하는 방법을 제공합니다.

글로벌 컨텍스트

전역 컨텍스트(함수 또는 객체 외부)에서 사용될 경우 전역 객체를 나타냅니다. 웹 브라우저에서 전역 객체는 window입니다.

console.log(this); // In a browser, this will log the window object
로그인 후 복사

기능 컨텍스트

함수 내부에서 사용하는 경우 함수 호출 방식에 따라 다릅니다.

일반 함수 호출

일반 함수 호출에서는 전역 개체(또는 엄격 모드에서는 정의되지 않음)를 나타냅니다.

function showThis() {
  console.log(this);
}

showThis(); // Logs window (or undefined in strict mode)
로그인 후 복사

메소드 호출

객체의 메소드로 함수를 호출할 경우 객체 자체를 의미합니다.

const person = {
  name: 'Alice',
  greet: function() {
    console.log(this.name);
  }
};

person.greet(); // Logs "Alice"
로그인 후 복사

생성자 컨텍스트

new 키워드와 함께 함수를 생성자로 사용하는 경우 새로 생성된 인스턴스를 나타냅니다.

function Person(name) {
  this.name = name;
}

const bob = new Person('Bob');
console.log(bob.name); // Logs "Bob"
로그인 후 복사

화살표 기능

화살표 함수는 동작이 다릅니다. 그들은 자신만의 이러한 맥락을 갖고 있지 않습니다. 대신 주변 어휘 컨텍스트에서 이를 상속받습니다.

const obj = {
  name: 'Carol',
  regularFunction: function() {
    console.log(this.name);
  },
  arrowFunction: () => {
    console.log(this.name);
  }
};

obj.regularFunction(); // Logs "Carol"
obj.arrowFunction();   // Logs undefined (or the global object in non-strict mode)
로그인 후 복사

이벤트 핸들러

이벤트 핸들러에서는 이벤트를 받은 요소를 의미합니다.

document.getElementById('myButton').addEventListener('click', function() {
  console.log(this); // Logs the button element
});
로그인 후 복사

명시적 바인딩

JavaScript는 호출, 적용, 바인딩을 사용하여 이 값을 명시적으로 설정하는 메서드를 제공합니다.

전화해서 신청하세요

call 및 apply 메소드를 사용하면 지정된 이 값으로 함수를 호출할 수 있습니다.

function introduce() {
  console.log(`Hello, my name is ${this.name}`);
}

const person = { name: 'Dave' };

introduce.call(person); // Logs "Hello, my name is Dave"
introduce.apply(person); // Logs "Hello, my name is Dave"
로그인 후 복사

호출과 적용의 차이점은 인수를 처리하는 방식입니다. 호출은 인수를 개별적으로 받아들이고 적용은 배열로 받아들입니다.

묶다

바인드 메소드는 호출 시 this 값이 제공된 값으로 설정되는 새 함수를 생성합니다.

function introduce() {
  console.log(`Hello, my name is ${this.name}`);
}

const person = { name: 'Eve' };

const boundIntroduce = introduce.bind(person);
boundIntroduce(); // Logs "Hello, my name is Eve"
로그인 후 복사

결론

JavaScript를 마스터하려면 this 키워드를 이해하는 것이 필수적입니다. 이것이 다양한 상황에서 어떻게 작동하는지 인식함으로써 더 예측 가능하고 유지 관리하기 쉬운 코드를 작성할 수 있습니다. 메소드, 생성자 또는 화살표 함수를 사용하여 작업하는 경우 이것이 어떻게 작동하는지 알면 일반적인 함정을 피하고 그 기능을 효과적으로 활용하는 데 도움이 됩니다.

위 내용은 JavaScript의 `this` 키워드 이해하기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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