JavaScript の this
キーワードは、特に self
が一貫して現在のオブジェクト インスタンスを参照する C#、Java、または Python などの言語から来た開発者にとって、混乱を引き起こすことがよくあります。 これらの言語とは異なり、JavaScript の this
は動的であり、その値は関数の呼び出しコンテキストによって決定されます。このガイドでは、this
の動作に影響を与えるさまざまなシナリオを要約します。
1.グローバルスコープ:
this
はグローバル オブジェクト (ブラウザーでは window
、Node.js では global
) を指します。<code class="language-javascript">console.log(this); // window or global</code>
this
は undefined
.<code class="language-javascript">"use strict"; console.log(this); // undefined</code>
2.関数内:
this
はグローバル オブジェクトを参照します。厳密モードでは、undefined
です。<code class="language-javascript">function myFunc() { console.log(this); } myFunc(); // window (non-strict), undefined (strict)</code>
3.オブジェクトメソッド:
this
はそのオブジェクトを参照します。<code class="language-javascript">const myObj = { name: "JavaScript", greet() { console.log(this.name); // this refers to myObj } }; myObj.greet(); // Output: JavaScript</code>
4.アロー関数:
this
がありません。これらは、語彙スコープ (周囲のコンテキスト) から this
を継承します。<code class="language-javascript">const myObj = { name: "JavaScript", arrowFunc: () => { console.log(this.name); // Inherits this from the global scope } }; myObj.arrowFunc(); // undefined (in browsers, this is window)</code>
5.コンストラクター:
this
は新しく作成されたインスタンスを参照します。<code class="language-javascript">class Person { constructor(name) { this.name = name; } greet() { console.log(`Hello, ${this.name}`); } } const person = new Person("Alice"); person.greet(); // Output: Hello, Alice</code>
6.明示的なバインディング (call
、apply
、bind
):
JavaScript 関数は、call
を明示的に設定するためのメソッド (apply
、bind
、this
) を持つオブジェクトです。
call
と apply
は、指定された this
値で関数を呼び出します。 call
はカンマ区切りの引数を使用します。 apply
は配列を受け取ります。<code class="language-javascript">function greet(greeting) { console.log(`${greeting}, ${this.name}`); } const user = { name: "Alice" }; greet.call(user, "Hello"); // Output: Hello, Alice greet.apply(user, ["Hi"]); // Output: Hi, Alice</code>
bind
は、this
が永続的にバインドされた新しい関数を返します。<code class="language-javascript">const boundGreet = greet.bind(user); boundGreet("Hello"); // Output: Hello, Alice</code>
7.イベントリスナー:
this
は、イベントをトリガーする要素を指します。<code class="language-javascript">const btn = document.querySelector("button"); btn.addEventListener("click", function() { console.log(this); // The button element });</code>
this
は要素ではなく、周囲のスコープから継承します。<code class="language-javascript">btn.addEventListener("click", () => { console.log(this); // this depends on the arrow function's definition context });</code>
8. setTimeout
/ setInterval
:
this
のデフォルトはグローバル オブジェクトです。<code class="language-javascript">setTimeout(function() { console.log(this); // window in browsers }, 1000);</code>
this
は字句的に継承されます。<code class="language-javascript">setTimeout(() => { console.log(this); // Inherits this from surrounding context }, 1000);</code>
9.クラス:
this
はクラス インスタンスを参照します。<code class="language-javascript">console.log(this); // window or global</code>
10.コンテキスト損失 (メソッド抽出):
メソッドを変数に割り当てたり、コールバックとして渡すと、this
バインディング損失が発生する可能性があります。
<code class="language-javascript">"use strict"; console.log(this); // undefined</code>
解決策: .bind(obj)
またはアロー関数を使用してコンテキストを維持します。
11. new
キーワード:
関数で new
を使用すると、新しいオブジェクトが作成され、this
はそのオブジェクトを参照します。
<code class="language-javascript">function myFunc() { console.log(this); } myFunc(); // window (non-strict), undefined (strict)</code>
概要テーブル:
Context |
this Refers To |
---|---|
Global (non-strict) | Global object (window/global) |
Global (strict) | undefined |
Object Method | The object owning the method |
Arrow Function | Lexical scope (surrounding context) |
Constructor/Class | The instance being created |
call , apply , bind
|
Explicitly defined value |
Event Listener | The element triggering the event |
setTimeout /setInterval
|
Global object (regular function), lexical scope (arrow function) |
new Keyword |
The newly created object |
未定義
呼び出し
、適用
、バインド
setTimeout
/setInterval
キーワード
this
これらのシナリオを理解することは、正しく予測可能な JavaScript コードを作成するために重要です。 予期しない 動作を避けるために、必要に応じて明示的バインディングなどのテクニックを利用することを忘れないでください。以上がJavaScript の this が他の OOP 言語と異なる理由の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。