জাভাস্ক্রিপ্ট ফাংশন বাইন্ড (JS Function Bind)

Web Development - জাভাস্ক্রিপ্ট (JavaScript) জাভাস্ক্রিপ্ট ফাংশন (JS Function) |
348
348

জাভাস্ক্রিপ্টে bind একটি গুরুত্বপূর্ণ মেথড যা ফাংশনের this কনটেক্সট নির্দিষ্ট করে এবং একটি নতুন ফাংশন তৈরি করে যা নির্দিষ্ট কনটেক্সটে কল করা হয়। এটি বিশেষভাবে উপকারী যখন আপনি ফাংশনের this মানকে কনট্রোল করতে চান, বিশেষ করে ইভেন্ট হ্যান্ডলার বা কলব্যাক ফাংশনে।


bind মেথড কি?

bind মেথডটি Function.prototype এর একটি মেথড, যা যেকোনো ফাংশনের সাথে ব্যবহার করা যেতে পারে। এটি মূল ফাংশনের this কনটেক্সটকে নির্দিষ্ট করে এবং একটি নতুন ফাংশন রিটার্ন করে, যা পরে কল করা যেতে পারে। এই নতুন ফাংশনটি নির্দিষ্ট this মান এবং নির্দিষ্ট আর্গুমেন্টের সাথে কাজ করে।

সিনট্যাক্স:

const newFunction = originalFunction.bind(thisArg, arg1, arg2, ...);
  • originalFunction: যে ফাংশনটি bind করতে চান।
  • thisArg: ফাংশনের this কনটেক্সট নির্ধারণ করে।
  • arg1, arg2, ...: ফাংশনের আর্গুমেন্ট, যা প্রাথমিকভাবে নির্ধারিত হয়।

call, apply এবং bind এর মধ্যে পার্থক্য

call, apply, এবং bind তিনটি মেথডই ফাংশনের this কনটেক্সট নির্ধারণ করতে ব্যবহৃত হয়, তবে তাদের মধ্যে কিছু মৌলিক পার্থক্য রয়েছে।

  • call:

    • সরাসরি ফাংশনকে কল করে।
    • আর্গুমেন্টগুলি আলাদা আলাদা পাস করতে হয়।
    function greet(greeting, punctuation) {
        console.log(`${greeting}, ${this.name}${punctuation}`);
    }
    
    const person = { name: "Alice" };
    
    greet.call(person, "Hello", "!");  // আউটপুট: Hello, Alice!
    
  • apply:

    • সরাসরি ফাংশনকে কল করে।
    • আর্গুমেন্টগুলি একটি অ্যারে বা অ্যারের মত অবজেক্টের মাধ্যমে পাস করতে হয়।
    function greet(greeting, punctuation) {
        console.log(`${greeting}, ${this.name}${punctuation}`);
    }
    
    const person = { name: "Bob" };
    
    greet.apply(person, ["Hi", "."]);  // আউটপুট: Hi, Bob.
    
  • bind:

    • একটি নতুন ফাংশন তৈরি করে যা নির্দিষ্ট this কনটেক্সটে কল করা হয়।
    • আর্গুমেন্টগুলি পূর্বনির্ধারিত হতে পারে।
    const person = {
        name: "Charlie",
        greet: function(greeting) {
            console.log(`${greeting}, my name is ${this.name}.`);
        }
    };
    
    const greetCharlie = person.greet.bind(person);
    greetCharlie("Good morning");  // আউটপুট: Good morning, my name is Charlie.
    

মূল পার্থক্য:

  • কল করার পদ্ধতি: call এবং apply ফাংশনকে তৎক্ষণাৎ কল করে, যেখানে bind একটি নতুন ফাংশন রিটার্ন করে।
  • আর্গুমেন্ট পাসিং: call এ আর্গুমেন্টগুলি আলাদা করে পাস করতে হয়, apply এ একটি অ্যারে ব্যবহার করতে হয়, এবং bind এ আর্গুমেন্টগুলি পূর্বনির্ধারিত হতে পারে।

bind মেথডের উদাহরণ

উদাহরণ ১: this কনটেক্সট নির্ধারণ করা

const person = {
    name: "David",
    greet: function(greeting) {
        console.log(`${greeting}, my name is ${this.name}.`);
    }
};

const anotherPerson = { name: "Eve" };

// `greet` মেথডটিকে `anotherPerson` এর কনটেক্সটে `bind` করা
const greetEve = person.greet.bind(anotherPerson);
greetEve("Hello");  // আউটপুট: Hello, my name is Eve.

ব্যাখ্যা: এখানে, person.greet ফাংশনটি bind ব্যবহার করে anotherPerson এর কনটেক্সটে রেফারেন্স করা হয়েছে। ফলে, this.name Eve রেফার করে।

উদাহরণ ২: পূর্বনির্ধারিত আর্গুমেন্টের সাথে ব্যবহার

function multiply(a, b) {
    return a * b;
}

const double = multiply.bind(null, 2);

console.log(double(5));  // আউটপুট: 10

ব্যাখ্যা: এখানে, multiply ফাংশনটি bind ব্যবহার করে a কে পূর্বনির্ধারিত করা হয়েছে 2। ফলে, double ফাংশনটি শুধুমাত্র b এর মান নেয় এবং a সবসময় 2 হয়।

উদাহরণ ৩: ইভেন্ট হ্যান্ডলারে bind ব্যবহার

<!DOCTYPE html>
<html>
<head>
    <title>Bind Example</title>
</head>
<body>
    <button id="myButton">Click Me</button>

    <script>
        const handler = {
            message: "Button was clicked!",
            handleClick: function() {
                console.log(this.message);
            }
        };

        const button = document.getElementById('myButton');
        button.addEventListener('click', handler.handleClick.bind(handler));
    </script>
</body>
</html>

ব্যাখ্যা: এখানে, ইভেন্ট হ্যান্ডলারে handler.handleClick ফাংশনটি bind ব্যবহার করে handler অবজেক্টের কনটেক্সটে রেফারেন্স করা হয়েছে। ফলে, বোতামে ক্লিক করলে this.message সঠিকভাবে Button was clicked! প্রিন্ট করবে।


bind এর ব্যবহার ক্ষেত্র

  • ইভেন্ট হ্যান্ডলার: this কনটেক্সট নির্ধারণ করতে ইভেন্ট হ্যান্ডলারে bind ব্যবহার করা হয়।
  • কলে ব্যাক ফাংশন: কলব্যাক ফাংশনে নির্দিষ্ট this কনটেক্সট বজায় রাখতে bind ব্যবহার করা যায়।
  • প্রোটোটাইপ মেথড: প্রোটোটাইপ মেথডগুলোকে নির্দিষ্ট অবজেক্টের সাথে যুক্ত করতে bind ব্যবহার করা হয়।
  • ফাংশন কারি: পূর্বনির্ধারিত আর্গুমেন্টের সাথে ফাংশনকে কারি করতে bind ব্যবহার করা যেতে পারে।

bind এর সীমাবদ্ধতা

  • পারফরম্যান্স: বড় স্কেলে বা বারবার bind ব্যবহার করলে পারফরম্যান্সে প্রভাব পড়তে পারে।
  • নতুন ফাংশন তৈরি: bind একটি নতুন ফাংশন তৈরি করে, যা কিছু ক্ষেত্রে অতিরিক্ত মেমরি ব্যবহার করতে পারে।
  • আর্গুমেন্টের সংখ্যা: কিছু ব্রাউজারে bind এর আর্গুমেন্টের সংখ্যা সীমাবদ্ধ থাকতে পারে, যদিও আধুনিক ব্রাউজারগুলো এই সীমা দূর করেছে।

সারাংশ

জাভাস্ক্রিপ্টে bind মেথডটি ফাংশনের this কনটেক্সট নির্ধারণ এবং একটি নতুন ফাংশন তৈরি করার জন্য ব্যবহৃত হয়, যা নির্দিষ্ট কনটেক্সটে কল করা হয়। এটি বিশেষভাবে ইভেন্ট হ্যান্ডলার, কলব্যাক ফাংশন, এবং ফাংশন কারির ক্ষেত্রে অত্যন্ত উপকারী। bind এর মাধ্যমে আপনি ফাংশনের this মানকে নিয়ন্ত্রণ করতে পারেন এবং আপনার কোডকে আরও নমনীয় এবং পুনরায় ব্যবহারযোগ্য করতে পারেন। তবে, এর পারফরম্যান্স এবং মেমরি ব্যবহারের বিষয়টি মাথায় রাখা জরুরি, বিশেষ করে বড় স্কেল প্রজেক্টে।


অতিরিক্ত রিসোর্স


bind মেথড সম্পর্কে আরও জানতে ও অনুশীলন করতে উপরের রিসোর্সগুলো দেখুন। দক্ষ ডেভেলপার হওয়ার জন্য ফাংশনের this কনটেক্সট নিয়ন্ত্রণ এবং bind মেথডের কার্যকর ব্যবহার জানা অত্যন্ত গুরুত্বপূর্ণ।

common.content_added_by
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion