ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript 高階関数の詳細な紹介 (コード付き)

JavaScript 高階関数の詳細な紹介 (コード付き)

不言
リリース: 2019-03-16 10:38:38
転載
3111 人が閲覧しました

この記事は、JavaScript の高階関数の詳細な紹介 (コード付き) です。一定の参考価値があります。必要な友人が参照できます。お役に立てれば幸いです。助けてくれた。

関数をデータとして使用し、いくつかの強力なパターンを解き放ちます。

JavaScript 高階関数の詳細な紹介 (コード付き)

高階関数

別の関数を受け取ったり返したりする関数は、高階関数と呼ばれます。

これが 高レベル である理由は、これが文字列、数値、またはブール値ではなく、 より高い レベルから関数を操作するためです。美しいメタ。

JavaScript で関数を使用すると、関数を変数として保存できます。

    配列で使用します。
  • オブジェクトとして指定します。 プロパティ (メソッド)
  • それらを引数として渡します
  • 他の関数からそれらを返します
  • 他のすべてのデータと同様に
。これが鍵です。

関数操作データ

文字列はデータです

sayHi = (name) => `Hi, ${name}!`;
result = sayHi('User');
console.log(result); // 'Hi, User!'
ログイン後にコピー

数値はデータです

double = (x) => x * 2;
result = double(4);
console.log(result); // 8
ログイン後にコピー

ブール型はデータです

getClearance = (allowed) => allowed ?
  'Access granted' :
  'Access denied';
result1 = getClearance(true);
result2 = getClearance(false);
console.log(result1); // 'Access granted'
console.log(result2); // 'Access denied'
ログイン後にコピー

オブジェクトはデータです

getFirstName = (obj) => obj.firstName;
result = getFirstName({
  firstName: 'Yazeed'
});
console.log(result); // 'Yazeed'
ログイン後にコピー

配列はデータです

len = (array) => array.length;
result = len([1, 2, 3]);
console.log(result); // 3
ログイン後にコピー

これらの 5 つのタイプは、すべての主要言語において第一級市民です。

なぜ彼らは第一級市民なのでしょうか?それらを渡したり、変数や配列に保存したり、計算への入力として使用したりできます。

任意のデータ

と同様に使用できます。

#関数はデータとしても使用できます

#JavaScript で関数をデータとして使用する 4 つの方法:

JavaScript 高階関数の詳細な紹介 (コード付き)

関数を渡す他の関数のパラメータとして設定

オブジェクトのプロパティとして設定
  1. 配列に保存
  2. 変数として設定
  3. 関数をパラメータとして
  4. isEven = (num) => num % 2 === 0;
    result = [1, 2, 3, 4].filter(isEven);
    console.log(result); // [2, 4]
    ログイン後にコピー
filter

isEven

を使用して保持する数値を決定する方法をご覧ください。 isEven は、別の関数 のパラメータ である関数です。 各数値の filter によって呼び出され、戻り値

true

または false を使用して、数値を保持するかどうかを決定します。または廃棄されました。 Return function<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">add = (x) =&gt; (y) =&gt; x + y;</pre><div class="contentsignin">ログイン後にコピー</div></div>

add

には 2 つのパラメータが必要ですが、一度にすべてを必要とするわけではありません。これは #xx

のみを受け取る関数であり、

y のみを受け取る関数を返します。 JavaScript では、文字列、数値、ブール値と同様に、関数を戻り値として使用できるためです。 必要に応じて、xy

をすぐに指定して、最初に

result = add(10)(20);
console.log(result); // 30
ログイン後にコピー
または xx を二重呼び出しして、 theny:

add10 = add(10);
result = add10(20);
console.log(result); // 30
ログイン後にコピー
最後の例に戻りましょう。 add10 は、1 つの引数を指定して add を呼び出した結果です。そしてそれをコンソールに出力します。

add10 は、y を受け取り、xy を返す関数です。 y を指定すると、すぐに計算が行われ、必要な最終結果が返されます。

JavaScript 高階関数の詳細な紹介 (コード付き)

高い再利用性

JavaScript 高階関数の詳細な紹介 (コード付き)おそらく、高階関数の最大の利点は、高い再利用性です。これがなければ、主要な JavaScript 配列メソッド (
map

filter

reduce) は存在しません。 これはユーザーリストです。彼らの情報に基づいていくつかの計算を行っていきます。

users = [{
  name: 'Yazeed',
  age: 25
}, {
  name: 'Sam',
  age: 30
}, {
  name: 'Bill',
  age: 20
}];
ログイン後にコピー
Map高階関数がない場合は、ループを使用して

map

の関数を模倣する必要があります。

getName = (user) => user.name;
usernames = [];
for (let i = 0; i 
ログイン後にコピー

さもなければ、これができます!

usernames = users.map(getName);
console.log(usernames);
// ["Yazeed", "Sam", "Bill"]
ログイン後にコピー
Filter高階関数のない世界でも、

filter

の機能を再実装するループが必要です。

startsWithB = (string) => string
  .toLowerCase()
  .startsWith('b');
namesStartingWithB = [];
for (let i = 0; i 
ログイン後にコピー

さもなければ、これができます!

namesStartingWithB = users
  .filter((user) => startsWithB(user.name));
console.log(namesStartingWithB);
// [{ "name": "Bill", "age": 20 }]
ログイン後にコピー
Reduceはい、reduce...高階関数がなければ、これほど多くの素晴らしいことは達成できません!!

以上がJavaScript 高階関数の詳細な紹介 (コード付き)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:segmentfault.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート