Higher-Order Function (HOF) হল সেই ধরনের ফাংশন যা অন্য ফাংশনকে আর্গুমেন্ট হিসেবে গ্রহণ করতে পারে বা একটি ফাংশন রিটার্ন করতে পারে, বা উভয়ই করতে পারে। JavaScript-এ ফাংশনগুলোকে First-Class Citizens হিসেবে বিবেচনা করা হয়, যার মানে ফাংশনগুলোকে ভেরিয়েবল হিসেবে স্টোর করা যায়, আর্গুমেন্ট হিসেবে পাস করা যায়, এবং রিটার্ন করা যায়। এই কারণে, JavaScript-এ Higher-Order Function তৈরি করা সহজ।
Higher-Order Function হলো একটি ফাংশন যা:
- একটি বা একাধিক ফাংশনকে ইনপুট হিসেবে নিতে পারে।
- একটি ফাংশনকে আউটপুট হিসেবে রিটার্ন করতে পারে।
এই ধরনের ফাংশন প্রোগ্রামিংকে আরো মডুলার এবং পুনঃব্যবহারযোগ্য করতে সাহায্য করে।
যেমনঃ-
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 হলো একটি Higher-Order Function যা sayHello নামের একটি ফাংশনকে আর্গুমেন্ট হিসেবে গ্রহণ করে এবং তারপর এটি কল করে।
JavaScript-এ অনেক বিল্ট-ইন Higher-Order Functions আছে, যা সাধারণত array-এ কাজ করতে ব্যবহৃত হয়। কিছু সাধারণ HOF হল:
map(): এটি একটি array-এর প্রতিটি উপাদানে একটি নির্দিষ্ট ফাংশন অ্যাপ্লাই করে এবং একটি নতুন array রিটার্ন করে।
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]
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]
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
forEach(): এটি একটি array-এর প্রতিটি উপাদানে নির্দিষ্ট ফাংশন অ্যাপ্লাই করে, কিন্তু কোনো নতুন array রিটার্ন করে না।
javascriptCopy code const numbers = [1, 2, 3]; numbers.forEach(function(num) { console.log(num * 2); // Output: 2, 4, 6 });
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 দিয়ে।
javascriptCopy code function fetchData(callback) { setTimeout(function() { callback("Data fetched successfully!"); }, 1000); } fetchData(function(message) { console.log(message); // Output: "Data fetched successfully!" });
এই উদাহরণে, fetchData একটি HOF, যা একটি ফাংশনকে আর্গুমেন্ট হিসেবে নেয় এবং সেটাকে নির্দিষ্ট সময় পরে কলব্যাক হিসেবে কল করে।
Higher-Order Functions JavaScript-এ একটি শক্তিশালী এবং বহুমুখী কনসেপ্ট যা কোডকে আরও সংগঠিত, পুনঃব্যবহারযোগ্য, এবং পরিষ্কার করে তোলে। ফাংশনকে ফার্স্ট-ক্লাস সিটিজেন হিসেবে গ্রহণ করে, JavaScript ডেভেলপারদের বিভিন্ন প্রোগ্রামিং প্যাটার্ন অনুসরণ করতে দেয়, যা ডেভেলপমেন্টকে আরও কার্যকর করে তোলে।
تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3