ホームページ > 記事 > ウェブフロントエンド > 「this」が JavaScript コールバックの呼び出し関数を参照していないのはなぜですか?
this が主張する場合: コールバック関数の 'this' を理解する
JavaScript では、関数呼び出し内の this の値は、関数が実行されるコンテキスト。ただし、これを引数として渡す場合、ルールが複雑になる可能性があります。
具体的には、次のシナリオが発生します。コールバック関数が引数として渡されるとき、なぜこれが呼び出し元の関数に設定されないのかコールバック?
「this」の階層を理解する
これがどこに設定されているかを理解するには、関数呼び出しの階層を考慮する必要があります。
ただし、randomFunction が呼び出す前に、コールバックでは、this.sumData.bind(this) を使用して新しい関数を作成します (ルール #5)。この新しい関数は元のコールバック関数を呼び出しますが、今度は obj (bind に渡される引数) にバインドされます。
コールバック関数の影響
メソッドを渡すときコールバックとしては、obj.method() として呼び出されないことを理解することが重要です。これは、コールバック関数内に正しい値が存在しないことを意味します。この問題を回避するには、bind() を使用してコールバック内で this の値を設定します。
その他の役立つメモ
以上が「this」が JavaScript コールバックの呼び出し関数を参照していないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。