2.7 জাভাস্ক্রিপ্টে হইস্টিং
Hoisting হচ্ছে জাভাস্ক্রিপ্ট এমন একটি পদ্ধতি যেখানে কোড এক্সিকিউশন করার আগে ভ্যারিয়েবল এবং ফাংশন ডিক্লেয়ারেশনগুলোকে তার বর্তমান Scope – এর শুরুতে নিয়ে যায়। উদাহরণস্বরূপঃ
উদাহরণের ব্যাখ্যা দেওয়ার আগে Hoisting সম্পর্কে কিছু কথা বলে নেই। যখন আমরা কাউকে Hoisting বুঝায় উপরের সংজ্ঞাটা দিয়েই বুঝায়। কিন্তু আসলেই কি জাভাস্ক্রিপ্ট তার সকল ভ্যারিয়েবলস এবং ফাংশন ডিক্লেয়ারেশনগুলোকে তার স্কোপের উপরে নিয়ে যায়? না, জাভাস্ক্রিপ্ট এমনটা কখনো করে না। যখন আপনি জাভাস্ক্রিপ্টের কোন কোড এক্সিকিউট করেন, জাভাস্ক্রিপ্ট ইঞ্জিন গ্লোবাল এক্সিকিউশন কন্টেক্সট তৈরি করে।
গ্লোবাল এক্সিকিউশন কন্টেক্সট এর দুটি phase আছে: creation এবং execution। creation phase চলার সময়, জাভাস্ক্রিপ্ট ইঞ্জিন সকল ভ্যারিয়েবলকে undefined হিসাবে ইনিশিয়ালাইজ করে। এবার চলুন আমরা Hoisting-এ ফিরে যাই।
জাভাস্ক্রিপ্টে Hoisting হচ্ছে দুই প্রকার।
- Variable Hoisting
- Function Hoisting
১. Variable Hoisting
উপরের console.log এর আউটপুট কি হবে? একটু চিন্তা করুন সময় নিয়ে। যাইহোক, উপরের কোডে কোন ভুল নেই। কারণ আমরা জানি জাভাস্ক্রিপ্ট ইঞ্জিন Creation phase-এ ভ্যারিয়েবল ডিক্লেয়ারেশনকে undefined হিসাবে ইনিশিয়ালাইজ করে। তাই, Execution phase-এ আউটপুট undefined হচ্ছে কারণ আমরা তার ভ্যালু ইনিশিয়ালাইজ হওয়ার আগেই log করে ফেলেছি। টেকনিক্যালি, কোডটি Execution phase-এ নিম্নলিখিত কোডের মত দেখাবেঃ
২. Functions Hoisting
ভ্যারিয়েবলের মত ফাংশনও Hoisted হয়। তাই আপনি আগে ফাংশন কল করে পরে ফাংশন ডিক্লেয়ার করতে পারবেন।
বিঃ দ্রঃ একটি কথা ভাল করে মনে রাখবেন যে জাভাস্ক্রিপ্ট ফাংশন এক্সপ্রেশনের ক্ষেত্রে কোন Hoisting করে না।
আপনাদের জন্যে একটি হোম টাস্ক। নিচের কোডের দুইটা console.log এর আউটপুট কি হবে?
- Variable Hoisting
console.log(x); // Uncaught ReferenceError: x is not definedlet x = 5;console.log(x); // Uncaught ReferenceError: x is not definedconst x = 5;console.log(x); // undefinedvar x = 5;
- Functions Hoisting
hoistedSuccess(); // Hoistedfunction hoistedSuccess() {console.log(‘This is Function Statement and it is hoisted’);}hoistedFailed(); // Not Hoistedconst hoistedFailed = () => {console.log(‘This function expression so it is not hoisteed.’);};
- জাভাস্ক্রিপ্টে হইস্টিং কি?
-
নিচের কোডের আউটপুট কি হবে?function add() {console.log(answer);var answer = 2;}add();
- নিচের কোডের আউটপুট কি হবে?
var temp = ‘hi’;function display() {console.log(temp);var temp = ‘bye’;}display();
- নিচের কোডের আউটপুট কি হবে?
function codeHoist() {a = 10;let b = 50;}codeHoist();console.log(a);console.log(b);
- নিচের কোডের আউটপুট কি হবে?
var x = 10;console.log(x);function test() {var x = 20;console.log(x);if (x > 10) {let x = 30;console.log(x);}console.log(x);}test();console.log(x);