Arrow Functions এর পরিচিতি

Arrow Functions - জাভাস্ক্রিপ্ট ইএস৬ (ES6) - Web Development

353

Arrow Functions ES6 (ECMAScript 2015) এর একটি গুরুত্বপূর্ণ বৈশিষ্ট্য, যা সাধারণ function কিওয়ার্ডের তুলনায় কোডকে আরও সংক্ষিপ্ত, পরিষ্কার এবং বেশি রিডেবল করে তোলে। Arrow Functions ব্যবহার করে ফাংশন ডিক্লেয়ারেশন অনেক সহজ এবং কোডের আকার ছোট করা যায়। এর পাশাপাশি, this কীওয়ার্ডের ব্যবহারেও কিছু গুরুত্বপূর্ণ পরিবর্তন এনেছে।


Arrow Function এর সিনট্যাক্স

Arrow Function এর মৌলিক সিনট্যাক্স:

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

যদি ফাংশনটির মধ্যে একটি একক এক্সপ্রেশন থাকে, তবে আপনি return এবং {} বাদ দিয়েও Arrow Function লিখতে পারেন। এই ক্ষেত্রে ফাংশনটি স্বয়ংক্রিয়ভাবে এক্সপ্রেশনটি রিটার্ন করবে।

const functionName = (parameters) => expression;

Arrow Functions এর উদাহরণ

1. সাধারণ Arrow Function

const greet = (name) => {
  return `Hello, ${name}`;
};

console.log(greet("John"));  // "Hello, John"

2. Implicit Return

যদি ফাংশনের মধ্যে শুধুমাত্র একটি এক্সপ্রেশন থাকে, তবে return কিওয়ার্ড এবং {} ব্রেসেস বাদ দেওয়া যায়। এটি implicit return নামে পরিচিত।

const greet = (name) => `Hello, ${name}`;

console.log(greet("John"));  // "Hello, John"

এখানে greet ফাংশনটি implicit return ব্যবহার করে। এক্সপ্রেশনটি সরাসরি রিটার্ন করা হয়েছে, কোন return কিওয়ার্ড ব্যবহার করা হয়নি।

3. Multiple Parameters

যদি একাধিক প্যারামিটার থাকে, তবে প্যারামিটারগুলো অবশ্যই ব্র্যাকেটে রাখতে হবে।

const sum = (a, b) => a + b;

console.log(sum(3, 4));  // 7

Arrow Functions এর বৈশিষ্ট্য

  1. কনসাইজ এবং পরিষ্কার সিনট্যাক্স (Concise and Clean Syntax): Arrow Functions কোডকে সংক্ষিপ্ত করে, যার ফলে কোডের রিডেবিলিটি (readability) অনেক বেড়ে যায়। এটি কোড লিখতে সাহায্য করে এবং কোডের আকার ছোট রাখে।
  2. Implicit Return: যদি ফাংশনের মধ্যে একটি একক এক্সপ্রেশন থাকে, তবে আপনি return কিওয়ার্ড ব্যবহার না করেও সেই এক্সপ্রেশনকে রিটার্ন করতে পারেন। এটি কোডের আকার ছোট রাখে এবং লেখার সময় সহজ করে।
  3. this এর নতুন আচরণ (Lexical this): সাধারণ function কিওয়ার্ড ব্যবহার করলে, this চলমান কনটেক্সট (ফাংশন কনটেক্সট) অনুযায়ী পরিবর্তিত হয়। তবে Arrow Functions এর this মূল কনটেক্সট (যেমন, ফাংশনটি কোথায় ডিফাইন করা হয়েছে) থেকে উত্তরাধিকারসূত্রে পাওয়া this কনটেক্সট ব্যবহার করে। Arrow Function এর মাধ্যমে this এর আচরণ অনেক সহজ এবং সাবলীল হয়, কারণ এটি lexical scoping অনুসরণ করে।

    উদাহরণ:

    const person = {
      name: "John",
      greet: function() {
        setTimeout(() => {
          console.log(`Hello, ${this.name}`);
        }, 1000);
      }
    };
    
    person.greet();  // "Hello, John" after 1 second
    

    এখানে, Arrow Function এর this মূল অবজেক্ট person এর this কে রেফারেন্স করে।

  4. Parameter Handling: Arrow Functions সাধারণ ফাংশনের মতো প্যারামিটার গ্রহণ করতে পারে। যদি একমাত্র প্যারামিটার থাকে, তাহলে প্যারামিটারগুলোর ব্র্যাকেট {} বাদ দেয়া যায়।

    উদাহরণ:

    const double = x => x * 2;
    console.log(double(4));  // 8
    

    যদি একাধিক প্যারামিটার থাকে, তবে সেগুলো অবশ্যই ব্র্যাকেট {} এর মধ্যে রাখতে হবে।

    const sum = (a, b) => a + b;
    console.log(sum(3, 4));  // 7
    

Arrow Functions এর সুবিধা

  • সংক্ষিপ্ততা: Arrow Functions সাধারণ ফাংশন ডিক্লেয়ারেশনের তুলনায় সংক্ষিপ্ত এবং আরও রিডেবল।
  • this এর সহজ ব্যবহার: this এর আচরণ সহজতর, কারণ Arrow Functions lexical scoping অনুসরণ করে।
  • Implicit Return: একক এক্সপ্রেশন থাকলে কোডকে আরও ছোট এবং পরিষ্কার করা সম্ভব।

Arrow Functions এর সীমাবদ্ধতা

  • Constructor হিসেবে ব্যবহার করা যাবে না: Arrow Functions constructor function হিসেবে কাজ করতে পারে না। অর্থাৎ, new কিওয়ার্ড ব্যবহার করে Arrow Function দিয়ে অবজেক্ট তৈরি করা যাবে না।

    const Person = (name) => {
      this.name = name;  // Error: Arrow functions cannot be used as constructors
    };
    
    const john = new Person("John");
    
  • No arguments Object: Arrow Functions এর মধ্যে arguments অবজেক্ট ব্যবহার করা যায় না। তবে, আপনি যদি arguments অবজেক্ট চান, তবে সাধারণ ফাংশন ব্যবহার করতে হবে।

    const sum = () => {
      console.log(arguments);  // Error: arguments is not defined
    };
    
    sum(1, 2, 3);
    

সারাংশ

Arrow Functions ES6 এর একটি শক্তিশালী বৈশিষ্ট্য যা কোডকে সংক্ষিপ্ত, পরিষ্কার এবং রিডেবল করে তোলে। এটি ফাংশন ডিক্লেয়ারেশনের জন্য একটি সহজ এবং কার্যকর উপায়, বিশেষ করে যখন ছোট ফাংশন লিখতে হয়। this এর সহজ ব্যবহারের জন্য Arrow Functions অনেক বেশি জনপ্রিয়। তবে কিছু সীমাবদ্ধতা রয়েছে, যেমন constructor function হিসেবে ব্যবহার করা যাবে না এবং arguments অবজেক্ট সমর্থন করে না।

Content added By
Promotion

Are you sure to start over?

Loading...