DEV Community

Cover image for JS Callback Function
Sabbir Hossen
Sabbir Hossen

Posted on

JS Callback Function

Callback function কি ?

jS এ কোন একটি function কে অন্য আরেকটা function এর প্যারামিটার হিসেবে pass করা হয় তখন সেই function কে callback function বলা হয় ।

function anotherFunction(callback){
  callback()
}
Enter fullscreen mode Exit fullscreen mode

উপরে anotherFunction নামে একটি function ডিফাইন করা হয়েছে,সেই function এর প্যারামিটারে আমরা callback নামে একটা প্যারামিটার নিয়েছি এবং সেটি anotherFuntion এর ভিতরে function call এর মতো করে call করেছি । অর্থাৎ আমরা আশা করি যে যখন ডেভেলপার anotherFunction কে invoke বা call করবে তখন anotherFunction এর argument হিসেবে একটি function কে pass করবে।

function simpleTextLog(){
  console.log("simple text showing")
}
anotherFunction(simpleTextLog)

Enter fullscreen mode Exit fullscreen mode

output : simple text showing

কেন Callback Function প্রয়োজন ?

মূলত asynchronous প্রোগ্রামিং এর ক্ষেত্রে callback function টি ব্যাপক ভাবে ব্যাবহার করা হয় তবুও নিচে ছোট একটি উদাহারন দিলাম।

আমরা জানি যে js এ কোড উপর থেকে নিচে লাইন বাই লাইন execute হয় । এখন যদি আমরা চাই, আমদের কোন একটা function এর কাজ শেষ হলে আরেকটি function এর কাজ শুরু হবে । সেই ক্ষেত্রে আমরা অনেক উপায়ে Function Sequence Control করতে পারি ।

যেমন : আমরা চাচ্ছি যে, দুইটি সংখ্যার যোগ ফল ডিসপ্লে করতে । সেই জন্য আমরা যোগ করার জন্য একটি function তৈরি করবো,যার কাজ হবে যোগ করা এবং ডিসপ্লে করার জন্য আরেকটি function তৈরি করবো,যার কাজ হবে শুধু ডিসপ্লে করা ।

Ex-1

function displaySum(sum){
 console.log(`total sum is ${sum}`);
}

function doSum(num1,num2){
   const sum = num1 + num2;
   return sum;
}

const result = doSum(5,7)
displaySum(result)

Enter fullscreen mode Exit fullscreen mode

Ex-2

function displaySum(sum){
 console.log(`total sum is ${sum}`);
}

function doSum(num1,num2){
   const sum = num1 + num2;
  displaySum(sum)
}

doSum(5,7)

Enter fullscreen mode Exit fullscreen mode

Ex-1 এ কাজটি করার জন্য আমাদের দুটি function আলাদা করে পর পর কল করা লাগতেছে । এখানে displaySum function টি doSum function এর উপর নির্ভরশীল ছিলো । তাই এই ক্ষেত্রে এই উদাহারন কে আমরা batter Function Sequence Control বলতে পারি না ।

Ex-2 এটিও batter Function Sequence Control বলতে পারি না । কারণ ফলাফল ডিসপ্লে করার জন্য doSum function থেকে displaySum function কে control করা যাচ্ছে না । মনে করেন আপনি চাচ্ছেন যে doSum function টি আপনার আপ্লিকেশনে 3 বার কল করতে চাচ্ছেন । এখন 3 বার কল করার সময় displaySum function কল হয়ে যাবে কিন্তু আপনি চাচ্ছেন যে doSum function থেকে শুধু মাত্র একবার বা আপনার ইচ্ছা মতো displaySum function কল করবেন। সেটি করার জন্যই আমাদের callback function ব্যাবহার করতে হবে।

callback function এর মাদ্ধমে doSum function থেকে displaySum function কে control করা যাবে।
যেমন :

function displaySum(sum){
 console.log(`total sum is ${sum}`);
}

function doSum(num1,num2,cb){
   const sum = num1 + num2;
  cb && cb(sum)
}

doSum(5,7,displaySum) //output: total sum is 12
doSum(5,7) //output: undefined
Enter fullscreen mode Exit fullscreen mode

উপরের কোডে displaySum function হলো callback function যেটি doSum function এর argument হিসবে pass হয়েছে ।

*নোট : callback function হিসেবে যখন কোন function কে argument হিসেবে পাঠাবেন তখন function এর reference পাঠাতে হয় । সেই জন্য function এর name এর সাথে কখনো "()" ব্র্যাকেট বা parentheses ব্যবহার করবেন না । যখন কোন একটা function এর name এর সাথে ব্র্যাকেট বা parentheses ব্যবহার করা হয় তখন সেই function টি কল হয়ে যায় । *

Top comments (2)

Collapse
 
sakibhasan09 profile image
Sakib Hasan

Nice post

Collapse
 
nisharga_kabir profile image
NISHARGA KABIR

wow beautifully explained...