JavaScript 関数呼び出し、適用、バインド メソッドのケース スタディ

JavaScript 関数呼び出し、適用、バインド メソッドのケース スタディ

要約する

1. 類似点

  1. どちらも、ターゲット関数が実行されると内部の this ポインターを変更できます。
  2. メソッドの最初のパラメータは、関数の実行時に内部の this 値を指定するために使用されます。
  3. 任意の数のパラメータをターゲット関数に渡すことをサポート
  4. メソッドの最初のパラメータに値を渡さない場合、または undefined または null を渡す場合、JavaScript の通常モードでは、ターゲット関数内の this は window オブジェクトを指し、厳密モードでは、それぞれ undefined または null を指します。

2. 違い

  1. apply() メソッドは 2 つのパラメータを受け入れますが、call() メソッドと bind() メソッドは複数のパラメータを受け入れます。
  2. apply() メソッドがターゲット関数にパラメータを渡す場合、メソッドの 2 番目のパラメータとしてパラメータ配列または引数オブジェクトを渡すだけで済みますが、call() メソッドと bind() メソッドでは、メソッドのパラメータの後にパラメータを 1 つずつリストする必要があります。
  3. call() メソッドと apply() メソッドが呼び出されると、ターゲット関数はすぐに実行されますが、bind() メソッドは実行されません。bind() メソッドは、ターゲット関数のコピーである新しい関数を返します。関数内の this は、bind() メソッドの最初のパラメータを指します。その後に新しい関数を実行することは、ターゲット関数を実行することと同じです。
  4. bind() メソッドのみが関数カリー化を実装しているため、ターゲット関数にパラメータを 2 回渡すことができます。

call() メソッド

  1. call() メソッドを呼び出すと、ターゲット関数がすぐに実行され、関数内の this の参照が変更されます。これはメソッドの最初のパラメータを指し、1 つずつリストされたパラメータは、ターゲット関数のパラメータとして 1 つずつ渡されます。
  2. 冒頭の要約の最後のポイントの例は次のとおりです。
/* 通常モード */

obj = {
  合計(a, b) {
    console.log(これ)
    a + bを返す
  }
}

// sum 関数の apply メソッドと bind メソッドを実行します。出力される内容は以下のようになります。obj.sum.call() // ウィンドウを印刷
obj.sum.call(undefined, 1, 2) // 印刷ウィンドウ
obj.sum.call(null, 1, 2) // 印刷ウィンドウ
/* 厳密モード */
「厳密な使用」

// sum関数のapplyメソッドとbindメソッドを実行し、以下のように出力します。obj.sum.call() // undefinedを出力します。
obj.sum.call(undefined, 1, 2) // undefined と表示される
obj.sum.call(null, 1, 2) // null を出力します

シミュレーションの実装

1. 要点

  1. myCall() メソッドが Function プロトタイプ オブジェクトに追加されます。ターゲット関数がこのメソッドを呼び出すと、myCall() メソッド内の this がターゲット関数を指します。
  2. ターゲット関数をコンテキスト オブジェクトのメソッドとして実行し、ターゲット関数内の this がコンテキスト オブジェクトを指すようにします。 。
  3. コンテキストオブジェクトからターゲット関数を削除します
  4. スプレッド演算子を使用して、ターゲット関数に渡されたパラメータを処理します。

2. call()、apply()、bind() メソッドのシミュレーション実装において、最初のパラメータが渡されない場合や undefined または null が渡された場合、ここでは JS 通常モードと厳密モードで統一された処理が行われ、つまり、対象関数内の this は window オブジェクトを指します。

3. コードは次のとおりです

Function.prototype.myCall = function (コンテキスト、...引数) {
  コンテキスト === 未定義 || コンテキスト === null の場合 {
    コンテキスト = ウィンドウ
  }
  // 次の行はコアコードです context.fn = this
  const 結果 = context.fn(...args)
  コンテキストを削除する.fn
  結果を返す
}

obj1 = {
  基本数: 1,
  合計(a, b) {
    console.log(これ)
    this.basicNum + a + b を返す
  }
}
obj2 = {
  基本数: 9
}
コンソールログ(obj1.sum.call(obj2, 2, 3)) // 14
コンソールログ(obj1.sum.myCall(obj2, 2, 3)) // 14

apply() メソッド

apply() メソッドを呼び出すと、ターゲット関数が直ちに実行され、関数内の this の参照が変更されます。これはメソッドの最初のパラメータを指します。2 番目のパラメータはパラメータ配列または引数オブジェクトです。各配列要素または引数オブジェクトによって表される各パラメータは、ターゲット関数のパラメータとして 1 つずつ渡されます。

シミュレーションの実装

1.要点

  1. myApply() メソッドが Function プロトタイプ オブジェクトに追加されます。ターゲット関数がこのメソッドを呼び出すと、myApply() メソッド内の this がターゲット関数を指します。
  2. ターゲット関数をコンテキスト オブジェクトのメソッドとして実行し、ターゲット関数内の this がコンテキスト オブジェクトを指すようにします。
  3. コンテキストオブジェクトからターゲット関数を削除します
  4. スプレッド演算子を使用して、ターゲット関数に渡されたパラメータを処理します。

2. コードは次のとおりです

Function.prototype.myApply = 関数 (コンテキスト、引数) {
  コンテキスト === 未定義 || コンテキスト === null の場合 {
    コンテキスト = ウィンドウ
  }
  // 次の行はコアコードです context.fn = this
  const 結果 = context.fn(...args)
  コンテキストを削除する.fn
  結果を返す
}

コンソール.log(obj1.sum.apply(obj2, [2, 3])) // 14
コンソール.log(obj1.sum.myApply(obj2, [2, 3])) // 14

bind() メソッド

  1. bind() メソッドを呼び出すと、新しい関数 (ターゲット関数のコピー) が返されます。関数内の this は、メソッドの最初のパラメータを指します。1 つずつリストされたパラメータは、ターゲット関数のパラメータとして 1 つずつ渡されます。その後に新しい関数を実行することは、ターゲット関数を実行することと同じです。
  2. bind() メソッドは関数のカリー化を実装しているため、ターゲット関数にパラメータを 2 回渡すことができます。最初のパラメータは bind() メソッドの最初のパラメータの後にリストされ、2 番目のパラメータは新しい関数にリストされます。

シミュレーションの実装

1. 要点

  1. myBind() メソッドが Function プロトタイプ オブジェクトに追加されます。ターゲット関数がこのメソッドを呼び出すと、myBind() メソッド内の this がターゲット関数を指します。
  2. ターゲット関数をコンテキスト オブジェクトのメソッドとして実行し、ターゲット関数内の this がコンテキスト オブジェクトを指すようにします。
  3. コンテキストオブジェクトからターゲット関数を削除します
  4. スプレッド演算子... を使用して、ターゲット関数に渡される最初のパラメータと後続のパラメータを処理します。

2. コードは次のとおりです

Function.prototype.myBind = function (context, ...initArgs) {
  コンテキスト === 未定義 || コンテキスト === null の場合 {
    コンテキスト = ウィンドウ
  }
  // この値をキャッシュする const _this = this
  関数を返す (...引数) {
    // 次の行はコアコードです context.fn = _this
    const 結果 = context.fn(...initArgs, ...args)
    コンテキストを削除する.fn
    結果を返す
  }
}

コンソール.log(obj1.sum.bind(obj2, 2)(3)) // 14
コンソール.log(obj1.sum.myBind(obj2, 2)(3)) // 14

関連する知識ポイント

  • JavaScriptにおけるthisの参照について

JavaScript 関数呼び出し、適用、およびバインド メソッドの詳細なケース分析に関するこの記事はこれで終わりです。JavaScript 関数呼び出し、適用、およびバインド メソッドに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後も 123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • JSの矢印関数におけるこのポイントの詳細な説明
  • JavaScript 関数構文の説明
  • Vue.jsのレンダリング関数の使い方の詳しい説明
  • JavaScript 基礎シリーズ: 関数とメソッド
  • JavaScript CollectGarbage 関数の例
  • JavaScript関数導入の詳しい説明

<<:  Nginx の realip モジュールの使い方の基礎学習

>>:  MySQL のキーとインデックスの違い

推薦する

MySQLカバーインデックスの利点

一般的な提案は、WHERE 条件のインデックスを作成することですが、これは実際には一方的です。インデ...

MySQL からエクスポートされた scv ファイル内の文字化けやジャンプ行の問題をすばやく解決します

仕事上の理由により、完全なオンライン化(​​つまり、すべてのデータがオンラインで完了し、インポートや...

ページング効果を実装するミニプログラム

この記事の例では、ページング効果表示を実現するためのミニプログラムの具体的なコードを参考までに共有し...

数ステップでサイバーパンク2077風の視覚効果を実現するCSS

背景記事を始める前に、賽博朋克とは何か、賽博朋克2077とは何かを簡単に理解しましょう。サイバーパン...

vue-router を遅延ロードする 3 つの方法のまとめ

遅延読み込みを使用しない 'vue' から Vue をインポートします。 '...

HTML を使用して IE8 および IE9 の互換表示モードを無効にするヒント

IE 8 以降では互換モードが追加され、これを有効にすると IE の下位バージョンでレンダリングされ...

一時ファイルを作成できないために MySQL が起動できない問題を解決する方法

問題の説明最近、仕事中に問題が発生しました。MySQL が起動に失敗しました。エラー ログは次のとお...

シンプルなショッピングカートの最も完全なコード分析を実装する JavaScript (ES6 オブジェクト指向)

この記事では、シンプルなショッピングカートを実装するためのJavaScriptの具体的なコードを参考...

Centos7 ベースの Varnish キャッシュ プロキシ サーバーを展開する

1. ワニスの概要1. ワニスの紹介Varnish は、新しいソフトウェア アーキテクチャを使用し、...

Reactでレシピシステムを実装する方法を解説した記事

目次1. レシピ集1.1 プロジェクトの背景1.2 テクノロジースタック1.3 開発環境1.4. プ...

忘れられたMySQLパスワードとログインエラーの問題について簡単に説明します

MySQL ログイン パスワードを忘れた場合、解決方法は実はとても簡単です。MySQL メイン構成フ...

jsは多次元配列を1次元配列に変換し、それを並べ替えます

目次まず多次元配列の平坦化についてお話しましょう方法 1: flat()方法 2: 空の文字列を連結...

Docker 可視化グラフィックツール portainer の詳細な説明

目次1. ポーテナーの紹介2. Portainer アーキテクチャの概要3. Portainerのイ...

Nginx 環境での WordPress マルチサイト構成の詳細な説明

WordPress のマルチサイト機能を使用すると、1 つの WordPress プログラムをインス...

MySQL InnoDB 監視 (システム層、データベース層)

MySQL InnoDB 監視 (システム層、データベース層) MySQL の監視に関しては、My...