var
, let
, const
এবং স্কোপ, হোইস্টিং এর মধ্যে পার্থক্য
নিচের টেবিলটি var
, let
এবং const
এর মধ্যে পার্থক্যগুলো তুলনা করে এবং আগের আলোচনা অনুযায়ী তাদের স্কোপ, হোইস্টিং, ভ্যালু অ্যাসাইনমেন্ট, TDZ ইত্যাদি বিষয়গুলো তুলে ধরছে:
বৈশিষ্ট্য | var |
let |
const |
---|---|---|---|
স্কোপ | ফাংশন স্কোপ (Function Scope) | ব্লক স্কোপ (Block Scope) | ব্লক স্কোপ (Block Scope) |
হোইস্টিং | হোইস্ট হয়, কিন্তু undefined থাকে (ডিক্লেয়ারেশন আগে অ্যাসাইনমেন্ট হয় না)। |
হোইস্ট হয়, কিন্তু TDZ এর কারণে এক্সেস করতে পারা যায় না (ডিক্লেয়ারেশন আগে অ্যাসাইনমেন্ট হয় না)। | হোইস্ট হয়, কিন্তু TDZ এর কারণে এক্সেস করতে পারা যায় না (ডিক্লেয়ারেশন আগে অ্যাসাইনমেন্ট হয় না)। |
ভ্যালু অ্যাসাইনমেন্ট | ডিক্লেয়ারেশনের পরে ভ্যালু অ্যাসাইন হয়। | ডিক্লেয়ারেশনের পরে ভ্যালু অ্যাসাইন হয়। | ডিক্লেয়ারেশনের পরে ভ্যালু অ্যাসাইন হয় এবং একবার অ্যাসাইন করলে পরিবর্তন সম্ভব নয়। |
TDZ (Temporal Dead Zone) | নেই। | আছে। let এর ক্ষেত্রে ডিক্লেয়ার করার আগে এক্সেস করা যাবে না। |
আছে। const এর ক্ষেত্রে ডিক্লেয়ার করার আগে এক্সেস করা যাবে না। |
মুল্যায়নযোগ্যতা(assignment) | পুনরায় অ্যাসাইনমেন্ট সম্ভব। | পুনরায় অ্যাসাইনমেন্ট সম্ভব। | একবার অ্যাসাইনমেন্ট হলে পুনরায় অ্যাসাইন করা সম্ভব নয়। |
গ্লোবাল স্কোপ | গ্লোবাল স্কোপে window অথবা global অবজেক্টে যুক্ত হতে পারে। |
গ্লোবাল স্কোপে window অথবা global অবজেক্টে যুক্ত হতে পারে না। |
গ্লোবাল স্কোপে window অথবা global অবজেক্টে যুক্ত হতে পারে না। |
ফাংশন স্কোপ | ফাংশনের ভিতরে var এক্সেস করা যায়। |
ফাংশনের ভিতরে let এক্সেস করা যায়। |
ফাংশনের ভিতরে const এক্সেস করা যায়। |
ব্লক স্কোপ | var ব্লক স্কোপ সমর্থন করে না (লুপ বা if ব্লকের ভিতরে এটি গ্লোবাল বা ফাংশন স্কোপেই থাকবে)। |
let ব্লক স্কোপ সমর্থন করে, অর্থাৎ ব্লক ভিতরে এক্সেসযোগ্য। |
const ব্লক স্কোপ সমর্থন করে, অর্থাৎ ব্লক ভিতরে এক্সেসযোগ্য। |
ডিটেইলসের মাধ্যমে পার্থক্য:
১. স্কোপ (Scope)
var
: ফাংশন স্কোপে থাকে, ব্লক স্কোপ সমর্থন করে না। অর্থাৎvar
দিয়ে ডিক্লেয়ার করা ভ্যারিয়েবলটি ফাংশনের বাইরে বা ব্লকের বাইরে অ্যাক্সেসযোগ্য হতে পারে যদি সেটি ফাংশনের ভিতরে ডিক্লেয়ার করা না হয়।let
এবংconst
: ব্লক স্কোপ সমর্থন করে। অর্থাৎ, এগুলি শুধুমাত্র তাদের ডিক্লেয়ার করা ব্লকের মধ্যে এক্সেসযোগ্য।
২. হোইস্টিং (Hoisting)
var
: হোইস্ট হয়, তবে ভ্যালুundefined
হয় (অ্যাসাইনমেন্টের আগে এক্সেস করা যাবে না)।let
এবংconst
: হোইস্ট হয় কিন্তু TDZ (Temporal Dead Zone) থাকে, অর্থাৎ ডিক্লেয়ারেশনের আগে এগুলি এক্সেস করা যাবে না এবং এর জন্যReferenceError
পাওয়া যাবে।
৩. TDZ (Temporal Dead Zone)
var
: TDZ নেই, তাই ভ্যালু undefined থাকা সত্ত্বেও কোড চলতে থাকে।let
এবংconst
: TDZ থাকে, অর্থাৎ আপনিlet
বাconst
ভ্যারিয়েবলকে ডিক্লেয়ার করার আগে এক্সেস করলেReferenceError
পাবেন।
৪. ভ্যালু অ্যাসাইনমেন্ট (Value Assignment)
var
: অ্যাসাইনমেন্টের পরেও ভ্যারিয়েবলটি পরিবর্তনযোগ্য থাকে।let
: অ্যাসাইনমেন্টের পরেও ভ্যারিয়েবলটি পরিবর্তনযোগ্য থাকে।const
: একবার অ্যাসাইন করার পর ভ্যালু পরিবর্তন করা সম্ভব নয়।
৫. গ্লোবাল স্কোপ (Global Scope)
var
: যদি গ্লোবাল স্কোপে ডিক্লেয়ার করা হয়, তবে সেটিwindow
বাglobal
অবজেক্টের অংশ হয়ে যায়। (ব্রাউজারেwindow
, নোডেglobal
)let
এবংconst
: গ্লোবাল স্কোপে ডিক্লেয়ার করার পরেওwindow
বাglobal
অবজেক্টে যুক্ত হয় না।
৬. ফাংশন স্কোপ (Function Scope)
- সব তিনটি
var
,let
,const
ফাংশনের ভিতরে এক্সেসযোগ্য। তবেlet
এবংconst
ব্লক স্কোপও সমর্থন করে, ফলে এগুলি শুধুমাত্র তাদের ডিক্লেয়ার করা ব্লকেই অ্যাক্সেসযোগ্য।
উদাহরণ দিয়ে বিশ্লেষণ:
উদাহরণ ১: var
হোইস্টিং
console.log(a); // undefined
var a = 10;
console.log(a); // 10
এখানে, a
প্রথমে হোইস্ট হয় এবং undefined
থাকে, তারপর 10
অ্যাসাইন হয়।
উদাহরণ ২: let
হোইস্টিং এবং TDZ
console.log(b); // ReferenceError: Cannot access 'b' before initialization
let b = 20;
এখানে b
এর হোইস্টিং ঘটে কিন্তু ডিক্লেয়ারেশন আগে এটি অ্যাক্সেস করার চেষ্টা করলে ReferenceError
পাওয়া যায়।
উদাহরণ ৩: const
হোইস্টিং এবং TDZ
console.log(c); // ReferenceError: Cannot access 'c' before initialization
const c = 30;
এখানে, c
এর হোইস্টিং ঘটলেও TDZ এর কারণে আগে অ্যাক্সেস করার চেষ্টা করলে ReferenceError
হবে।
উদাহরণ ৪: const
এর এক্সেস এবং রিডিফাইনেবল
const d = 40;
d = 50; // TypeError: Assignment to constant variable.
এখানে, const
দিয়ে ডিক্লেয়ার করা ভ্যারিয়েবলটি রিডিফাইন করা সম্ভব নয়।
সারাংশ
var
গ্লোবাল স্কোপে এবং ফাংশন স্কোপে কাজ করে, তবে ব্লক স্কোপে কাজ করে না এবং এটি undefined থাকে হোইস্টিংয়ে।let
এবংconst
ব্লক স্কোপে কাজ করে, কিন্তু হোইস্টিংয়ের পর TDZ থাকে, যার কারণে এগুলি ডিক্লেয়ার করার আগে এক্সেস করা যায় না।const
একবার ভ্যালু অ্যাসাইন করা হলে পুনরায় ভ্যালু পরিবর্তন করা সম্ভব নয়, তবেlet
এবংvar
ভ্যালু পুনরায় অ্যাস
াইন করা যেতে পারে।
এই সব বিষয়গুলোর সমন্বয়ে জাভাস্ক্রিপ্টে var
, let
, এবং const
এর পার্থক্য বোঝা খুবই গুরুত্বপূর্ণ!
নিচে প্রতিটি var
, let
, এবং const
এর মধ্যে স্কোপের পার্থক্য সহ তাদের ব্লক, ফাংশন, গ্লোবাল স্কোপে অ্যাসাইন করার উদাহরণ দেয়া হলো।
উদাহরণ সহ পার্থক্য:
১. গ্লোবাল স্কোপে অ্যাসাইনমেন্ট:
// var
var x = 10;
console.log(window.x); // 10 (Window Object এ x যোগ হবে)
let y = 20;
console.log(window.y); // undefined (window object এ y যোগ হয় না)
const z = 30;
console.log(window.z); // undefined (window object এ z যোগ হয় না)
এখানে দেখা যাচ্ছে var
গ্লোবাল স্কোপে থাকলে সেটা window
অবজেক্টে যুক্ত হয়ে যায়, তবে let
এবং const
গ্লোবাল স্কোপে থাকলেও window
অবজেক্টে যুক্ত হয় না।
২. ফাংশন স্কোপে অ্যাসাইনমেন্ট:
function testFunction() {
// var
var a = 5;
console.log(a); // 5 (ফাংশনের ভিতরে কাজ করবে)
// let
let b = 10;
console.log(b); // 10 (ফাংশনের ভিতরে কাজ করবে)
// const
const c = 15;
console.log(c); // 15 (ফাংশনের ভিতরে কাজ করবে)
}
testFunction();
এখানে, var
, let
, এবং const
সবগুলোই ফাংশন স্কোপে থাকে, তাই ফাংশনের ভিতরে সেগুলোর এক্সেস করা যাবে।
৩. ব্লক স্কোপে অ্যাসাইনমেন্ট:
if (true) {
// var
var a = 5;
console.log(a); // 5 (ফাংশন স্কোপে, বাইরের স্কোপেও অ্যাক্সেস হবে)
// let
let b = 10;
console.log(b); // 10 (ব্লক স্কোপে, এই ব্লকের বাইরে এক্সেস করা যাবে না)
// const
const c = 15;
console.log(c); // 15 (ব্লক স্কোপে, এই ব্লকের বাইরে এক্সেস করা যাবে না)
}
console.log(a); // 5 (ফাংশন স্কোপে, বাইরের স্কোপে এক্সেস করা যাবে)
console.log(b); // ReferenceError: b is not defined (ব্লক স্কোপের বাইরে এক্সেস করা যাবে না)
console.log(c); // ReferenceError: c is not defined (ব্লক স্কোপের বাইরে এক্সেস করা যাবে না)
এখানে দেখা যাচ্ছে:
var
ব্লক স্কোপের মধ্যে থাকা সত্ত্বেও ফাংশন স্কোপে অ্যাক্সেসযোগ্য, অর্থাৎ সেটি বাইরের স্কোপে চলে যায়।let
এবংconst
ব্লক স্কোপে থাকে, তাই তাদের অ্যাক্সেস ব্লকের বাইরে করা যাবে না।
৪. let
এবং const
এর TDZ (Temporal Dead Zone):
// let
console.log(a); // ReferenceError: Cannot access 'a' before initialization
let a = 5;
// const
console.log(b); // ReferenceError: Cannot access 'b' before initialization
const b = 10;
এখানে let
এবং const
এর মধ্যে TDZ বিদ্যমান। আপনি যেগুলো ডিক্লেয়ার করার আগে এক্সেস করতে গেলে ReferenceError
পাবেন।
৫. ভ্যালু পুনরায় অ্যাসাইনমেন্ট:
// var
var x = 10;
x = 20; // পুনরায় অ্যাসাইন করা সম্ভব
console.log(x); // 20
// let
let y = 30;
y = 40; // পুনরায় অ্যাসাইন করা সম্ভব
console.log(y); // 40
// const
const z = 50;
z = 60; // TypeError: Assignment to constant variable.
console.log(z); // Error
এখানে:
var
এবংlet
এ ভ্যালু পুনরায় অ্যাসাইন করা সম্ভব, তবেconst
এর মান একবার অ্যাসাইন করার পর আর পরিবর্তন করা যায় না।
সারাংশ:
var
: গ্লোবাল স্কোপে window বা global অবজেক্টে যোগ হয়ে যায়, ফাংশন স্কোপে থাকে, এবং ব্লক স্কোপ সমর্থন করে না।let
: ব্লক স্কোপ সমর্থন করে, ফাংশন স্কোপে কাজ করে, তবে TDZ (Temporal Dead Zone) থাকে, তাই ডিক্লেয়ারেশন করার আগে এক্সেস করা যাবে না।const
: ব্লক স্কোপে কাজ করে, ফাংশন স্কোপে কাজ করে, এবং একবার মান অ্যাসাইন করার পর তা পরিবর্তন করা যায় না। TDZ থেকেও এক্সেস করা যাবে না ডিক্লেয়ারেশনের আগে।