jsでのこれの意味

下次还敢
リリース: 2024-05-01 09:36:16
オリジナル
489 人が閲覧しました

JavaScript では、this キーワードは現在の実行コンテキスト内のオブジェクトを指します。具体的には、グローバル実行コンテキストはウィンドウ オブジェクトを指し、関数実行コンテキストは関数が属するオブジェクトを指し、関数内の 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 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート