Javascript: call() & apply() と binding() の再訪
call() と apply() を使用すると変更が可能になります関数のコンテキストを取得し、引数を手動または配列として渡すと、bind() メソッドは独自のメソッドを提供します。 approach.
bind() を使用する場合
Bind は、後で実行するために事前定義されたコンテキストを使用して関数を作成する必要がある場合に特に便利です。関数をすぐに呼び出す call() や apply() とは異なり、bind は指定されたコンテキスト セットを持つ新しい関数を返します。
次の例は違いを示しています。
var obj = { x: 81, getX: function() { return this.x; } }; alert(obj.getX.bind(obj)()); // 81 alert(obj.getX.call(obj)); // 81 alert(obj.getX.apply(obj)); // 81
この例ではたとえば、bind() は、実行時にそのコンテキストが常に obj オブジェクトに設定される新しい関数を作成します。これは、関数コンテキストがあいまいになる可能性があるイベント リスナーで特に役立ちます。
使用例
例:
function MyObject(element) { this.elm = element; element.addEventListener('click', this.onClick.bind(this), false); } MyObject.prototype.onClick = function(e) { var t = this; // do something with [t]... // Without bind, the context of this function would be different. };
結論
バインドを使用すると、事前定義されたコンテキストを使用して関数を作成できますこれにより、イベント処理、非同期プログラミング、およびコンテキストの維持が重要なその他のシナリオで特に役立ちます。 call() と apply() は即時の関数呼び出しを提供しますが、bind は固定コンテキストで後で実行するための関数を返します。
以上がJavascript の `call()` と `apply()` と `bind()`: いつどちらを使用するべきですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。