ホームページ > ウェブフロントエンド > jsチュートリアル > 高階関数 (HOF) の詳細な説明。

高階関数 (HOF) の詳細な説明。

WBOY
リリース: 2024-08-29 12:37:43
オリジナル
1282 人が閲覧しました

Higher-Order Functions (HOFs) সম্পর্কে বিস্তারিত আলোচনা

高次関数 (HOF) は、別の関数を引数として受け入れるか、関数を返すか、あるいはその両方ができる関数です。 JavaScript の関数は 第一級国民 とみなされます。これは、関数を変数として保存したり、引数として渡したり、返したりできることを意味します。このため、JavaScript で高階関数を簡単に作成できます。

高階関数は次のような関数です:

  1. は 1 つ以上の関数を入力として受け取ることができます。
  2. は出力として関数を返すことができます。

このような関数は、プログラミングをよりモジュール化し、再利用可能にするのに役立ちます。

例:-

function higherOrderFunction(callback) {
    // কিছু কাজ করল
    console.log("Executing the callback function now...");
    callback();  // কলব্যাক ফাংশনকে কল করা হচ্ছে
}

function sayHello() {
    console.log("Hello, World!");
}

// higherOrderFunction কে একটি ফাংশন হিসেবে call করা হল
higherOrderFunction(sayHello); 
// Output:
// Executing the callback function now...
// Hello, World!
ログイン後にコピー

上記の例では、higherOrderFunction は、sayHello という名前の関数を引数として受け取り、それを呼び出す高階関数です。

高階関数の利点:

  1. コードの再利用性: HOF を使用すると、共通関数を再利用可能にできます。
  2. 抽象化: HOF は、複雑なロジックを抽象化することで簡素化します。
  3. モジュール性: コードをより小さな部分に分割すると、管理が容易になります。
  4. 関数型プログラミング: HOF は関数型プログラミングの基礎であり、関数には状態や可変データが含まれません。

高階関数の使用:

  • イベント ハンドラー: HOF は、特定のイベントの後に実行するアクションを定義するイベント ハンドラーとしてよく使用されます。
  • 非同期プログラミング: AJAX 呼び出しなどの非同期操作では、AJAX 呼び出しの後に実行されるアクションは HOF によって決定されます。
  • カリー化: カリー化は関数を分解し、部分引数を持つ新しい関数を作成します。
  • 構成: HOF は、小さな関数を組み合わせて複雑な関数を形成するために使用できます。

JavaScript の一般的な高階関数

JavaScript には多くの高階関数が組み込まれており、配列の操作によく使用されます。一般的な HOF には次のようなものがあります:

  1. map(): 指定された関数を配列の各要素に適用し、新しい配列を返します。

    javascriptCopy code
    const numbers = [1, 2, 3, 4];
    const doubled = numbers.map(function(num) {
        return num * 2;
    });
    console.log(doubled); // Output: [2, 4, 6, 8]
    
    
    ログイン後にコピー
  2. filter(): এটি একটি array-এর উপাদানগুলোকে একটি নির্দিষ্ট condition-এর ভিত্তিতে ফিল্টার করে এবং একটি নতুন array রিটার্ন করে।

    javascriptCopy code
    const ages = [18, 21, 16, 25, 30];
    const adults = ages.filter(function(age) {
        return age >= 18;
    });
    console.log(adults); // Output: [18, 21, 25, 30]
    
    
    ログイン後にコピー
  3. reduce(): এটি একটি array-কে একটি single value-তে রিডিউস করে, একটি accumulator ব্যবহার করে।

    javascriptCopy code
    const numbers = [1, 2, 3, 4];
    const sum = numbers.reduce(function(acc, num) {
        return acc + num;
    }, 0);
    console.log(sum); // Output: 10
    
    ログイン後にコピー
  4. forEach(): এটি একটি array-এর প্রতিটি উপাদানে নির্দিষ্ট ফাংশন অ্যাপ্লাই করে, কিন্তু কোনো নতুন array রিটার্ন করে না।

    javascriptCopy code
    const numbers = [1, 2, 3];
    numbers.forEach(function(num) {
        console.log(num * 2); // Output: 2, 4, 6
    });
    
    ログイン後にコピー
  5. Function Returning Function : JavaScript-এ, ফাংশন Higher-Order Functions এর মাধ্যমে অন্য একটি ফাংশনকে রিটার্ন করতে পারে। এটি শক্তিশালী কৌশল যেমন currying এবং function composition করতে সক্ষম করে।

javascriptCopy code
function createMultiplier(multiplier) {
    return function(number) {
        return number * multiplier;
    };
}

const double = createMultiplier(2);
const triple = createMultiplier(3);

console.log(double(5)); // Output: 10
console.log(triple(5)); // Output: 15
ログイン後にコピー

এই উদাহরণে, createMultiplier একটি Higher-Order Function যা একটি ফাংশনকে রিটার্ন করে যা একটি সংখ্যাকে গুণ করবে নির্দিষ্ট multiplier দিয়ে।

  1. Callback Functions : Callback Functions হল একটি ফাংশন যা একটি অন্য ফাংশনের আর্গুমেন্ট হিসেবে পাস করা হয় এবং প্রয়োজন অনুযায়ী সেই ফাংশনের ভিতরে এক্সিকিউট করা হয়। Callback Functions মূলত Higher-Order Functions এর একটি বিশেষ রূপ।
javascriptCopy code
function fetchData(callback) {
    setTimeout(function() {
        callback("Data fetched successfully!");
    }, 1000);
}

fetchData(function(message) {
    console.log(message); // Output: "Data fetched successfully!"
});
ログイン後にコピー

এই উদাহরণে, fetchData একটি HOF, যা একটি ফাংশনকে আর্গুমেন্ট হিসেবে নেয় এবং সেটাকে নির্দিষ্ট সময় পরে কলব্যাক হিসেবে কল করে।

Conclusion

Higher-Order Functions JavaScript-এ একটি শক্তিশালী এবং বহুমুখী কনসেপ্ট যা কোডকে আরও সংগঠিত, পুনঃব্যবহারযোগ্য, এবং পরিষ্কার করে তোলে। ফাংশনকে ফার্স্ট-ক্লাস সিটিজেন হিসেবে গ্রহণ করে, JavaScript ডেভেলপারদের বিভিন্ন প্রোগ্রামিং প্যাটার্ন অনুসরণ করতে দেয়, যা ডেভেলপমেন্টকে আরও কার্যকর করে তোলে।

以上が高階関数 (HOF) の詳細な説明。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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