Advanced Data Transformation Techniques

Map, Filter, Reduce এবং Chaining - জাভাস্ক্রিপ্ট ইএস৬ (ES6) - Web Development

322

ES6 (ECMAScript 2015) নতুন ডেটা ট্রান্সফরমেশন টেকনিকগুলোর মাধ্যমে ডেটা প্রক্রিয়াকরণকে আরও কার্যকর, সংক্ষিপ্ত এবং উপযোগী করেছে। এই টেকনিকগুলো ডেটা ফিল্টারিং, ম্যাপিং, গ্রুপিং, এবং আরো উন্নত কাজের জন্য ব্যবহৃত হয়। এখানে আমরা আলোচনা করব Array এবং Object এর সাথে কিছু অগ্রসর Data Transformation টেকনিকের সম্পর্কে, যেমন map(), filter(), reduce(), Object Destructuring, Spread এবং Rest অপারেটর।


Array Transformation Techniques

Array থেকে ডেটা প্রক্রিয়াকরণ ও ট্রান্সফরমেশনকে অনেক সহজ ও কার্যকরী করতে ES6 নতুন Array methods প্রদান করেছে। এর মধ্যে map(), filter(), reduce(), find(), এবং forEach() মেথডগুলো বেশ গুরুত্বপূর্ণ।

map() Method

map() মেথড ব্যবহার করে একটি Array এর প্রতিটি আইটেমকে পরিবর্তন করা যায় এবং নতুন একটি Array তৈরি করা হয়।

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

console.log(squaredNumbers);  // [1, 4, 9, 16, 25]

এখানে, map() ব্যবহার করে আমরা numbers অ্যারের প্রতিটি আইটেমকে স্কয়ারে পরিণত করেছি।

filter() Method

filter() মেথড একটি নতুন Array তৈরি করে যা শুধুমাত্র শর্ত পূর্ণ করে এমন আইটেমগুলো ধারণ করে।

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

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

এখানে, filter() মেথড ব্যবহার করে আমরা শুধুমাত্র ইভেন (even) সংখ্যাগুলোকে আলাদা করেছি।

reduce() Method

reduce() মেথডটি অ্যারের আইটেমগুলিকে একত্রিত বা কম্বাইন করতে ব্যবহৃত হয় এবং একটি একক ফলাফল প্রদান করে।

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

console.log(sum);  // 15

এখানে, reduce() মেথডে acc (অ্যাকুমুলেটর) ব্যবহার করে আমরা সব সংখ্যার যোগফল বের করেছি।

find() Method

find() মেথড ব্যবহার করে অ্যারে থেকে একটি নির্দিষ্ট শর্ত পূর্ণ করা প্রথম আইটেম পাওয়া যায়।

const numbers = [1, 2, 3, 4, 5];
const firstEven = numbers.find(num => num % 2 === 0);

console.log(firstEven);  // 2

এখানে, find() মেথডটি প্রথম ইভেন নম্বরটি ফেরত দেয়।

forEach() Method

forEach() মেথড একটি কাস্টম ফাংশন নির্ধারণ করে, যা প্রতিটি অ্যারে আইটেমের জন্য কল হয়।

const numbers = [1, 2, 3, 4, 5];
numbers.forEach(num => console.log(num * 2));

এখানে, forEach() ব্যবহার করে প্রতিটি আইটেমকে ২ গুণ করা হয়েছে এবং কনসোলে প্রিন্ট করা হয়েছে।


Advanced Object Transformation Techniques

ES6 তে Object Destructuring এবং Spread/Rest অপারেটরের মতো নতুন ফিচার যোগ করা হয়েছে, যা অবজেক্টের ডেটা সহজে ট্রান্সফর্ম করতে সাহায্য করে।

Object Destructuring

Object Destructuring ব্যবহার করে অবজেক্ট থেকে একাধিক ভ্যালু সহজেই এক্সট্র্যাক্ট করা যায়।

const person = {
  name: "John",
  age: 30,
  city: "New York"
};

const { name, age } = person;
console.log(name, age);  // John 30

এখানে, Object Destructuring এর মাধ্যমে name এবং age ভ্যালু আলাদা করে নিয়েছি।

Spread Operator (Object)

Spread Operator (...) ব্যবহার করে একটি অবজেক্টের সমস্ত প্রপার্টি অন্য একটি অবজেক্টে কপি করা যায়।

const person = {
  name: "John",
  age: 30
};

const address = {
  city: "New York",
  country: "USA"
};

const personWithAddress = { ...person, ...address };

console.log(personWithAddress);
// { name: "John", age: 30, city: "New York", country: "USA" }

এখানে, spread operator দিয়ে person এবং address অবজেক্টের প্রপার্টি একত্রিত করা হয়েছে।

Rest Operator (Function Parameters)

Rest Operator (...) ব্যবহার করে ফাংশনে একাধিক আর্গুমেন্টকে একটি অ্যারে হিসেবে ধারণ করা যায়।

function sum(...numbers) {
  return numbers.reduce((acc, num) => acc + num, 0);
}

console.log(sum(1, 2, 3, 4));  // 10

এখানে, rest operator ব্যবহার করে একাধিক প্যারামিটারকে numbers অ্যারে হিসেবে গ্রহন করা হয়েছে এবং তারপরে reduce() মেথড দিয়ে তাদের যোগফল বের করা হয়েছে।


Practical Example: Complex Data Transformation

ধরা যাক, আমাদের কাছে একটি অ্যারে আছে যেটিতে ব্যবহারকারীর তথ্য রয়েছে এবং আমরা বিভিন্ন map(), filter(), এবং reduce() ব্যবহার করে কিছু ট্রান্সফরমেশন করতে চাই।

const users = [
  { name: "Alice", age: 25, city: "New York" },
  { name: "Bob", age: 30, city: "London" },
  { name: "Charlie", age: 35, city: "Paris" },
  { name: "David", age: 40, city: "New York" }
];

// 1. New York শহরের সব ব্যবহারকারীর নাম সংগ্রহ করা
const newYorkUsers = users.filter(user => user.city === "New York").map(user => user.name);
console.log(newYorkUsers);  // ["Alice", "David"]

// 2. ব্যবহারকারীদের বয়সের গড় বের করা
const averageAge = users.reduce((acc, user) => acc + user.age, 0) / users.length;
console.log(averageAge);  // 32.5

// 3. বয়সের ভিত্তিতে শ্রেণিবদ্ধ করা
const groupedByAge = users.reduce((groups, user) => {
  if (user.age <= 30) {
    groups.young.push(user);
  } else {
    groups.old.push(user);
  }
  return groups;
}, { young: [], old: [] });

console.log(groupedByAge);
// { young: [ { name: "Alice", age: 25, city: "New York" }, { name: "Bob", age: 30, city: "London" } ], 
//   old: [ { name: "Charlie", age: 35, city: "Paris" }, { name: "David", age: 40, city: "New York" } ] }

এখানে, আমরা filter(), map(), এবং reduce() মেথড ব্যবহার করে একাধিক ট্রান্সফরমেশন করেছি এবং ডেটার উপর বিভিন্ন প্রক্রিয়া প্রয়োগ করেছি।


সারাংশ

ES6 এর Array এবং Object টেকনিকগুলো যেমন map(), filter(), reduce(), spread এবং rest অপারেটর, আমাদের ডেটা ট্রান্সফরমেশন অনেক সহজ এবং কার্যকরী করে। এগুলো ব্যবহারের মাধ্যমে আপনি কম্প্লেক্স ডেটা প্রক্রিয়া ও ম্যানিপুলেশনকে আরও দক্ষতার সাথে করতে পারেন।

Content added By
Promotion

Are you sure to start over?

Loading...