>웹 프론트엔드 >JS 튜토리얼 >js에서 이것의 의미

js에서 이것의 의미

下次还敢
下次还敢원래의
2024-05-01 09:36:16489검색

JavaScript에서 this 키워드는 현재 실행 컨텍스트의 객체를 가리킵니다. 구체적으로 말하면, 전역 실행 컨텍스트는 함수가 속한 개체를 가리킵니다. 메서드 실행 컨텍스트는 호출 메서드의 개체를 가리킵니다. JavaScript에서 this의 의미

JavaScript에서 this는 현재 실행 컨텍스트에서 개체를 가리키는 특수 키워드입니다. 조금 복잡하게 들릴 수도 있지만 실제로는 이해하기 쉽습니다. js에서 이것의 의미

실행 컨텍스트

JavaScript 코드는 실행될 때 실행 컨텍스트라고 하는 다른 컨텍스트에서 실행됩니다. 각 실행 컨텍스트에는 고유한 this 개체가 있습니다.

this 是一个特殊的关键字,它指向当前执行上下文中的对象。这听起来可能有点复杂,但它实际上很容易理解。

执行上下文

JavaScript 代码在执行时是在不同的上下文环境中运行的,称为执行上下文。每个执行上下文都有自己的 this 对象。

全局执行上下文

当 JavaScript 代码在浏览器中运行时,它首先在全局执行上下文中运行。在这种情况下,this 指向 window 对象。

函数执行上下文

当一个函数被调用时,它会创建自己的执行上下文。在这个上下文中,this 指向函数所属的对象。

方法执行上下文

当一个对象的方法被调用时,它会创建自己的执行上下文。在这种情况下,this 指向调用方法的对象。

箭头函数

箭头函数是一个例外。它们不创建自己的执行上下文,而是继承父函数的执行上下文。因此,箭头函数中的 this 始终指向父函数的 this 对象。

实践示例

以下示例展示了如何根据不同的执行上下文,this 如何引用不同的对象:

<code class="javascript">// 全局执行上下文
console.log(this); // 输出: Window

// 函数执行上下文
function myFunction() {
  console.log(this); // 输出: Window
}
myFunction();

// 方法执行上下文
const obj = {
  name: 'John',
  sayHello: function() {
    console.log(this.name); // 输出: John
  }
};
obj.sayHello();

// 箭头函数
const arrowFunction = () => {
  console.log(this); // 输出: Window
};
arrowFunction();</code>

通过了解 this

전역 실행 컨텍스트🎜🎜🎜JavaScript 코드가 브라우저에서 실행되면 먼저 전역 실행 컨텍스트에서 실행됩니다. 이 경우 thiswindow 개체를 가리킵니다. 🎜🎜🎜함수 실행 컨텍스트🎜🎜🎜함수가 호출되면 자체 실행 컨텍스트가 생성됩니다. 이 맥락에서 this는 함수가 속한 객체를 가리킵니다. 🎜🎜🎜메서드 실행 컨텍스트🎜🎜🎜객체의 메서드가 호출되면 자체 실행 컨텍스트가 생성됩니다. 이 경우 this는 메서드가 호출되는 개체를 가리킵니다. 🎜🎜🎜화살표 함수🎜🎜🎜화살표 함수는 예외입니다. 자체 실행 컨텍스트를 생성하지 않지만 상위 함수의 실행 컨텍스트를 상속합니다. 따라서 화살표 함수의 this는 항상 상위 함수의 this 개체를 가리킵니다. 🎜🎜🎜연습 예🎜🎜🎜다음 예는 this가 다양한 실행 컨텍스트에 따라 어떻게 다른 개체를 참조할 수 있는지 보여줍니다. 🎜rrreee🎜JavaScript에서 this 개체가 작동한다는 것을 이해하면, 더 깔끔하고 유지 관리하기 쉬운 코드를 작성할 수 있습니다. 🎜

위 내용은 js에서 이것의 의미의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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