JS の compose 関数と pipe 関数の使い方の詳細な説明

JS の compose 関数と pipe 関数の使い方の詳細な説明

作成機能

compose 関数は、ネストされた順序で実行する必要がある関数をフラット化できます。ネストされた実行とは、1 つの関数の戻り値が別の関数のパラメーターとして使用されることを意味します。簡単な要件を考えてみましょう。この要件は非常に単純なので、計算関数で次のように実行できます。

定数計算 = x => (x + 10) * 10;
res = calculate(10);とします。
コンソール.log(res); // 200

しかし、前に説明した関数型プログラミングによれば、複雑なステップをいくつかの単純で再利用可能なステップに分解できるので、加算関数と乗算関数を分離しました。

定数を追加します = x => x + 10;
定数乗算 = x => x * 10;

// 計算は 2 つの関数のネストされた計算に変更され、add 関数の戻り値は multiply 関数のパラメーターとして使用されます。let res = multiply(add(10));
console.log(res); // 結果は依然として200です

上記の計算方法は関数のネストされた実行であり、私たちの compose の役割は、ネストされた実行メソッドをパラメーターとしてフラット化することです。ネストされた実行が発生すると、内部のメソッド、つまり右側のメソッドが最初に実行され、次に左側に戻ります。私たちの compose メソッドも右側のパラメーターから開始されるため、目標は非常に明確です。次のような compose メソッドが必要です。

// パラメータは右から左に実行されるため、multiply が最初に実行され、add が最後に実行されます。let res = compose(multiply, add)(10);

これについて話す前に、使用する必要がある関数を見てみましょう: Array.prototype.reduce

配列プロトタイプの削減

配列のreduceメソッドは累積効果を実現できます。このメソッドは2つのパラメータを受け取ります。1つ目は累積メソッド、2つ目は初期化値です。アキュムレータは 4 つのパラメータを受け取ります。最初のパラメータは最後に計算された値で、2 番目のパラメータは配列の現在の値です。主にこの 2 つのパラメータが使用されます。最後の 2 つのパラメータは一般的には使用されません。これらは現在のインデックスと現在の反復の配列です。

定数arr = [[1, 2], [3, 4], [5, 6]];
// prevRes の初期値は渡された [] であり、各反復後に計算された値になります。const flatArr = arr.reduce((prevRes, item) => prevRes.concat(item), []);

console.log(flatArr); // [1, 2, 3, 4, 5, 6]

Array.prototype.reduceRight

Array.prototype.reduce は左から右に反復処理します。右から左に反復処理する必要がある場合は、Array.prototype.reduceRight を使用します。

定数arr = [[1, 2], [3, 4], [5, 6]];
// prevRes の初期値は渡された [] であり、各反復後に計算された値になります。const flatArr = arr.reduceRight((prevRes, item) => prevRes.concat(item), []);

console.log(flatArr); // [5, 6, 3, 4, 1, 2]

では、この compose メソッドをどのように実装するのでしょうか? Array.prototype.reduceRight を使用する必要があります。

const compose = 関数(){
  // 受信したパラメータを配列に格納します。args == [乗算、加算]
  const args = [].slice.apply(引数);
  関数(x)を返す{
    args.reduceRight((res, cb) => cb(res), x) を返します。
  }
}

// このメソッドを検証してみましょう let calculate = compose(multiply, add);
res = calculate(10);とします。
console.log(res); // 結果は依然として200です

上記の compose 関数は、ES6 を使用するとより簡潔になります。

const compose = (...args) => x => args.reduceRight((res, cb) => cb(res), x);

Redux のミドルウェアは compose を使用して実装されており、webpack の loader の読み込み順序も compose を使用して実装されているため、右から左になります。

パイプ関数

パイプ関数はcompose関数と同じで、パラメータもフラットに配置されますが、順序は左から右になります。実装してみましょう。reduceRight を Reduce に変更するだけです。

const パイプ = 関数(){
  const args = [].slice.apply(引数);
  関数(x)を返す{
    args.reduce((res, cb) => cb(res), x) を返します。
  }
}

// パラメータの順序を左から右に変更します。let calculate = pipe(add, multiply);
res = calculate(10);とします。
console.log(res); // 結果は依然として200です

ES6 ライティング:

const パイプ = (...args) => x => args.reduce((res, cb) => cb(res), x)

以上がJSにおけるcompose関数とpipe関数の使い方の詳しい説明です。JSについてさらに詳しく知りたい方は、123WORDPRESS.COM内の他の関連記事もぜひご注目ください!

以下もご興味があるかもしれません:
  • Node.jsパイプはソースコード解析を実装します
  • Node.jsのストリームとパイプのメカニズムの原理と実装を理解する
  • JavaScript Reduceの詳しい説明
  • JavaScript Array.reduce ソースコードの詳細な説明
  • JavaScript における Reduce() の 5 つの基本的な使用例
  • JS配列reduce()メソッドの原理と使い方の分析
  • JS配列Reduceメソッドの機能と使い方の詳しい説明
  • JS配列メソッドreduceの使用例の分析
  • JavaScript の Reduce と ReduceRight の説明

<<:  Linux システムで MySQL データベースの解凍バージョンをインストールして構成する方法

>>:  MySQLのslave_exec_modeパラメータの詳細な説明

推薦する

DockerにELKをインストールしてJSON形式のログ分析を実装する方法

ELKとは何ですか? ELK は、Elastic が提供するログ収集およびフロントエンド表示ソリュー...

MySQL データベースのホットスタンバイにおける問題点の分析

以前、MySQL データベースのデュアルマシン ホット スタンバイの設定方法を紹介しました。ご興味の...

HTML ハイパーリンク内の中国語文字化けの分析と解決

Vm 内のハイパーリンク URL は、Get 要求のパラメータとして中国語と連結する必要があります。...

ノードでシェルスクリプトを使用する方法

背景開発中、特定の状況でビジネス ロジックをバッチ処理するためのスクリプトが必要になる場合があります...

デジタル時計効果を実現するJavaScript

この記事の例では、JavaScriptでデジタル時計効果を実装するための具体的なコードを参考までに共...

5分でWebRTCビデオチャットを構築する

前回の記事では、Ubuntu 上の webrtc ベースの多人数ビデオチャット サービスの詳細なコー...

HTML テーブル マークアップ チュートリアル (40): ヘッダーの暗い境界線の色属性 BORDERCOLORDARK

テーブルヘッダーでは、暗い境界線の色を個別に定義できます。基本的な構文<TH 境界線の色を暗く...

MYSQLは、ショッピングカートに追加する際に重複追加を防ぐためのサンプルコードを実装します。

序文最近、仕事の都合で、APP ショッピングカートの注文支払いに取り組んでいました。テスト中にバグが...

JSON.stringify のさまざまな用途のまとめ

序文json を使用したことがある人なら、オブジェクトを文字列化してからバックエンドに送信するのが一...

MySQLの文字セット設定を5分で理解しましょう

目次1. コンテンツの概要2. 文字セットと文字順序の概念と関係3. MySQL でサポートされてい...

MySQL 8.0はJSONを扱えるようになりました

目次1. 概要2. JSON基本ツール3. JSONパス式4. JSONを検索して変更する序文:長い...

Unicodeの一般的な記号

Unicode は、世界中のすべてのテキストと記号に対応できる国際組織によって開発された文字エンコー...

Mysql クラシック高レベル/コマンドライン操作 (クイック) (推奨)

サーバーとデータベースの構築方法を学ぶ必要があるため、最近は SQL 言語を独学で学び始めました。デ...

React NativeプロジェクトでLottieアニメーションを使用する方法

Lottie は、Airbnb が開発した iOS、Android、React Native 向けの...

MySQL方言の簡単な紹介

データベースはさておき、人生における方言とは何でしょうか?方言とは、ある場所特有の言語です。他の場所...