this が議論するとき: コールバック関数の 'this' を理解する
JavaScript では、関数呼び出し内の this の値は、関数が実行されるコンテキスト。ただし、これを引数として渡す場合、ルールが複雑になる可能性があります。
具体的には、次のシナリオが発生します。コールバック関数が引数として渡されるとき、なぜこれが呼び出し元の関数に設定されないのかコールバック?
「this」の階層を理解する
なぜこれがどこに設定されているかを理解するには、次のことを行う必要があります。関数呼び出しの階層を考慮してください:
ただし、randomFunction はコールバックを呼び出す前に、this.sumData.bind(this) を使用して新しい関数を作成します (ルール #5)。この新しい関数は元のコールバック関数を呼び出しますが、これは obj (バインドに渡される引数) にバインドされています。
コールバック関数の影響
メソッドを渡すときコールバックとしては、obj.method() として呼び出されないことを理解することが重要です。これは、コールバック関数内に正しい値が存在しないことを意味します。この問題を回避するには、bind() を使用してコールバック内で this の値を設定します。
その他の役立つメモ
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3