Arrow Functions এবং Underscore.js

Underscore.js এর সাথে Modern JavaScript Features - আন্ডারস্কোর.জেএস (underscorejs) - Web Development

248

Arrow Functions (অ্যারো ফাংশন) কি?

Arrow functions (অ্যারো ফাংশন) হল একটি সংক্ষিপ্ত এবং আধুনিক সিনট্যাক্সে JavaScript ফাংশন ডেফিনিশন। ES6 (ECMAScript 2015) এর মাধ্যমে JavaScript-এ arrow functions পরিচিত হয়, যা কোড লেখার সময় সহজতা, এবং this কনটেক্সটের ব্যবহারে স্বচ্ছতা আনে। অ্যারো ফাংশনগুলির সাধারণ সিনট্যাক্স হল:

const functionName = (parameters) => {
  // function body
};

এটি সাধারণ ফাংশনের তুলনায় আরো ছোট এবং সরল হয়। অ্যারো ফাংশনগুলির সাথে কিছু গুরুত্বপূর্ণ বৈশিষ্ট্য থাকে:

  • this লেক্সিক্যালি বাঁধা থাকে: অ্যারো ফাংশনগুলিতে this এর মান ফাংশনটি যেখানে ডিক্লেয়ার করা হয়েছে সেই কনটেক্সট থেকে উত্তরাধিকারী হয়, অর্থাৎ this এর মান ফাংশন কলের কনটেক্সট অনুযায়ী পরিবর্তিত হয় না।
  • সংক্ষিপ্ত সিনট্যাক্স: আপনি যদি একটি একক এক্সপ্রেশন ফাংশন ব্যবহার করেন, তাহলে ব্রেস ({}) এবং return কিওয়ার্ডও বাদ দিতে পারবেন।

Arrow Function উদাহরণ:

// সাধারণ ফাংশন
const add = function(a, b) {
  return a + b;
};

// অ্যারো ফাংশন
const addArrow = (a, b) => a + b;

console.log(add(2, 3)); // 5
console.log(addArrow(2, 3)); // 5

এখানে, অ্যারো ফাংশনটি সাধারণ ফাংশনের তুলনায় সংক্ষিপ্ত এবং পরিষ্কার।


Underscore.js এবং Arrow Functions

Underscore.js ফাংশনাল প্রোগ্রামিং এর একটি শক্তিশালী লাইব্রেরি, যেখানে বেশ কিছু হায়ার অর্ডার ফাংশন এবং অ্যারে অপারেশন রয়েছে, যেমন _.map(), _.filter(), _.reduce() ইত্যাদি। অ্যারো ফাংশনগুলির সাথে Underscore.js একত্রে ব্যবহার করা খুবই সুবিধাজনক, কারণ অ্যারো ফাংশনগুলির সংক্ষিপ্ত এবং পরিষ্কার সিনট্যাক্স Underscore.js এর কোল্লেকশন ফাংশনের সাথে মিলে যায়।

অ্যারো ফাংশন ব্যবহার করলে কোড আরও সহজ এবং পরিষ্কার হয়ে ওঠে, এবং this কনটেক্সটের সমস্যা এড়ানো যায়, যা সাধারণ ফাংশনের সাথে ঘটতে পারে।


Arrow Functions এবং Underscore.js এর হায়ার অর্ডার ফাংশন

Underscore.js অনেক হায়ার অর্ডার ফাংশন প্রদান করে, যেগুলোর সাথে অ্যারো ফাংশন ব্যবহার করা যায়। নিচে কিছু সাধারণ Underscore.js ফাংশনের সাথে অ্যারো ফাংশন ব্যবহার করা হয়েছে:

১. _.map() — অ্যারে এর প্রতিটি উপাদান পরিবর্তন

_.map() ফাংশনটি একটি অ্যারের প্রতিটি উপাদানকে একটি নির্দিষ্ট ফাংশনের মাধ্যমে প্রক্রিয়াকরণ করে একটি নতুন অ্যারে রিটার্ন করে।

উদাহরণ:

const numbers = [1, 2, 3, 4];
const doubled = _.map(numbers, (num) => num * 2);

console.log(doubled); // [2, 4, 6, 8]

এখানে, অ্যারো ফাংশনটি _.map() ফাংশনের সাথে ব্যবহৃত হয়েছে, যা প্রতিটি উপাদানকে দ্বিগুণ করে একটি নতুন অ্যারে রিটার্ন করছে।

২. _.filter() — কন্ডিশনের ভিত্তিতে উপাদান ফিল্টার করা

_.filter() ফাংশনটি একটি অ্যারের এমন উপাদানগুলি ফিল্টার করে, যা একটি নির্দিষ্ট শর্ত পূরণ করে।

উদাহরণ:

const numbers = [1, 2, 3, 4, 5];
const evenNumbers = _.filter(numbers, (num) => num % 2 === 0);

console.log(evenNumbers); // [2, 4]

এখানে, অ্যারো ফাংশনটি _.filter() ফাংশনের সাথে ব্যবহৃত হয়েছে, যা কেবলমাত্র সেগুলি ফিল্টার করে যেগুলি সংখ্যা পূর্ণভাবে ভাগযোগ্য ২ দিয়ে।

৩. _.reduce() — অ্যারে এর উপাদান একত্রিত করা

_.reduce() ফাংশনটি একটি অ্যারের সমস্ত উপাদানকে একত্রিত করে একটি একক মানে পরিণত করে।

উদাহরণ:

const numbers = [1, 2, 3, 4];
const sum = _.reduce(numbers, (total, num) => total + num, 0);

console.log(sum); // 10

এখানে, _.reduce() ফাংশনের সাথে অ্যারো ফাংশন ব্যবহৃত হয়েছে যা অ্যারের সমস্ত উপাদানকে যোগ করে মোট মান (sum) নির্ধারণ করছে।

৪. _.each() — অ্যারে বা অবজেক্টের প্রতিটি উপাদানে কাজ করা

_.each() ফাংশনটি একটি অ্যারে বা অবজেক্টের প্রতিটি উপাদান বা কী-ভ্যালুর জন্য নির্দিষ্ট একটি ফাংশন রান করে।

উদাহরণ:

const numbers = [1, 2, 3, 4];
_.each(numbers, (num) => {
  console.log(num * 2);
});

// Output:
// 2
// 4
// 6
// 8

এখানে, অ্যারো ফাংশনটি _.each() ফাংশনের সাথে ব্যবহৃত হয়েছে, যা অ্যারের প্রতিটি উপাদানকে দ্বিগুণ করে কনসোলে প্রিন্ট করছে।


Underscore.js এর সাথে Arrow Functions এর সুবিধা

  • সংক্ষিপ্ততা: অ্যারো ফাংশনগুলি সংক্ষিপ্ত এবং সহজভাবে লিখতে সাহায্য করে, যার ফলে কোড কমপ্যাক্ট এবং পরিষ্কার হয়।
  • this কনটেক্সট সমস্যা কমানো: অ্যারো ফাংশনগুলি this এর মানকে নির্দিষ্ট করে, তাই ফাংশনাল প্রোগ্রামিংয়ের মধ্যে this কনটেক্সটের সমস্যা কমে যায়, যা সাধারণ ফাংশনে দেখা যায়।
  • পুনঃব্যবহারযোগ্য এবং ফাংশনাল কোড: Underscore.js এবং অ্যারো ফাংশন ব্যবহারে কোড পুনঃব্যবহারযোগ্য হয়ে ওঠে, কারণ আপনি ছোট ছোট ফাংশন তৈরি করতে পারেন এবং তাদের একত্রিত করে একটি বড় কাজ সম্পন্ন করতে পারেন।

সারাংশ

Arrow Functions এবং Underscore.js একে অপরের সাথে ভালোভাবে কাজ করে, বিশেষত যখন ফাংশনাল প্রোগ্রামিং প্যাটার্ন এবং হায়ার অর্ডার ফাংশন ব্যবহৃত হয়। Underscore.js ফাংশনগুলি যেমন _.map(), _.filter(), _.reduce(), _.each() ইত্যাদি অ্যারো ফাংশনের সাথে ব্যবহৃত হলে কোড আরও সংক্ষিপ্ত, পরিষ্কার এবং কার্যকর হয়। অ্যারো ফাংশনগুলির মাধ্যমে this কনটেক্সট ব্যবস্থাপনা সহজ হয়, এবং কোডের কার্যকারিতা বৃদ্ধি পায়।

Content added By
Promotion

Are you sure to start over?

Loading...