Javascript 共通高階関数の詳細

Javascript 共通高階関数の詳細

Higher Order function 。英語ではHigher Order functionと呼ばれます。別の関数をパラメータとして受け取ることができる関数を高階関数と呼びます。

例:

関数 add(x, y, f) {
 f(x) + f(y) を返します。
}

//コードで検証:
追加(-5, 6, Math.abs); // 11

1. 一般的な高階関数

ES6配列にいくつかの新しいメソッドが追加されましたが、そのうちmapreducefilterすべて高階関数です。また、通常のsortも高階関数です。以下に3つの新しい方法を紹介します。

1.1、フィルター

filterは、配列をフィルタリングし、条件を満たすデータを返し、新しい配列を形成してそれを返し、条件を満たさないデータを破棄します。

例1:配列内の100未満のデータを取り出し、新しい配列に格納する

grad = [ 102, 188, 55, 66, 200, 800 ] とします。
arr2 = grad.filter( 関数(item){
 返品商品 <= 100
})
console.log("arr2",arr2) // 55, 66

上記の例では、 filterに渡されるパラメータは関数です。渡された関数は各要素に順番に作用し、戻り値がtruefalseかに基づいて要素を保持するか破棄するかを決定します。要件を満たすのは 55 と 66 のみなので、新しい配列にはこれら 2 つの要素のみが含まれます。

1.2、地図

マップとは地図を描くことを意味します。

元の配列は新しい配列にマップされ、元の配列は変更されずに、戻り値は新しい配列になります。新しい配列の長さは元の配列と変わりません。

例 2:データの各要素を 2 倍に拡大します。

arr2 = [ 55, 66 ] とする
arr3 = arr2.map( 項目 => {
 返品商品*2
})
//結果を返す [110, 132]

上記の例では、 mapが受け取るパラメータは関数であり、各要素に順番に作用して要素を 2 倍に拡大し、任意の複雑な操作を実行することもできます。

1.3、減らす

reduce配列を要約するプロセスです。多くの場合、配列が入力され、データの一部が出力されます。合計や平均の計算によく使用されます。

例 3:前の例で返された結果を合計します。

合計をarr3.reduce((tmp,item)=>{とする
 tmp+item を返す
})
//結果242を返す

さて、ここからが本題です。上記の 3 つの例を組み合わせた場合、最終的にどれだけシンプルに書けるでしょうか?

執筆責任者:

// 複雑な記述 let grad = [102,188,55,66,200,800]
arr2 = grad.filter(function(item){
 返品商品 <= 100
})
arr3 = arr2.map(item=>{ とする
 返品商品*2
})
合計をarr3.reduce((tmp,item)=>{とする
 tmp+item を返す
})

簡単な書き方:

// 簡単な書き方 let sum2 = grad
           .filter( 項目 => { 項目を返す <= 100 })
          .map(item=>{戻り値アイテム*2})
          .reduce((tmp,item)=>{tmp+itemを返す})

Javascript一般的な高階関数の詳細に関するこの記事はこれで終わりです。Javascript Javascript一般的な高階関数の詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • JavaScriptの高階関数の詳細な説明
  • JavaScriptの高階関数の詳細な研究
  • JavaScript 関数型プログラミングにおける高階関数の使用法の分析
  • JS高階関数の原理と使用例の分析
  • JavaScriptの高階関数の魅力を徹底解説
  • JSの高階関数5つを共有する

<<:  MySQL で削除されたレコードが有効にならない理由のトラブルシューティング

>>:  http.server に基づく LAN サーバーの構築プロセスの分析

推薦する

IE8ブラウザはWebページ標準に完全互換となる

<br />海外メディアの報道によると、マイクロソフトはソフトウェアの相互運用性への取り...

MySQL カーソルの概念と使用法の詳細な説明

この記事では、例を使用して MySQL カーソルの概念と使用方法を説明します。ご参考までに、詳細は以...

CSSは、マウスを線の上に置くと線全体の色を変える効果を実現します。

まとめ:以下のように、CSS で指定した行にマウスを置いたときに行全体の色を変更する方法を示します。...

Nginx バージョンのスムーズなアップグレードソリューションの詳細説明

目次背景: Nginx スムーズ アップグレード ソリューションフォールバック手順要約する背景:負荷...

JavaScriptでよく使われる配列重複排除実戦ソースコード

アレイの重複排除は、通常、就職面接中に遭遇し、アレイの重複排除方法のコードを手動で記述することが求め...

Javascriptでシンプルなナビゲーションバーを実装

この記事では、参考までに、シンプルなナビゲーションバーを実装するためのJavascriptの具体的な...

Vue3 における computed の新しい使用例のまとめ

vue3 での computed の使い方。vue3 は vue2 のオプション API と互換性が...

Mysql のフィールドのデータの一部をバッチ置換する (推奨)

MYSQL のフィールドのデータの一部をバッチで置き換えます。具体的な導入は次のとおりです。 1....

CSSは背景画像の画面適応を実現する

ログインページなどのホームページを作成する場合、大きな背景画像を配置する必要があり、さまざまな画面の...

Vue+SpringBoot で Alipay サンドボックス決済を実装するためのサンプルコード

まず、Alipay サンドボックスから一連のものをダウンロードします。多くのブログで取り上げられてお...

MySQL テーブルの読み取り、書き込み、インデックス作成、その他の操作の SQL ステートメントの効率最適化の問題を分析します。

前回は、Explain 実行プランの表示、インデックスの分析など、MySQL での SQL クエリの...

MySQL マスタースレーブ同期の原理と応用

目次1. マスタースレーブ同期原理マスタースレーブ同期アーキテクチャ図(非同期同期)マスタースレーブ...

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

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

MySQL ルート パスワードをリセットするときに発生する「不明な列 'password'」問題を解決する方法

夜にMACの電源を入れたところ、突然ルートアカウントがMySQLに正常にログインできなくなったため、...

CentOS の起動時に RabbitMq ソフトウェアを自動的に起動する方法

1. /etc/init.dディレクトリに新しいrabbitmqを作成します。 [root@loca...