var, let & const - তফাৎ কি? 🤷‍♂️

Mahfuz SwaronMahfuz Swaron
4 min read

var, let, const হচ্ছে জাভাস্ক্রিপ্টে ভ্যারিয়েবল ডিক্লেয়ার করার keyword । অর্থাৎ, কোনো ভ্যারিয়েবল লিখার শুরুতে এগুলোর যেকোনো ১ টিকে লিখতে হয়। কাজ সবগুলোর এক হলেও ভাব কিন্তু আলাদা। তো কোন কোন দিক দিয়ে আলাদা চলুন দেখে নেয়া যাক —

Redeclaration & Reassignment ( রিডিক্লেয়ারেশন ও রিঅ্যাআসাইনমেন্ট ):

ধরেন একটা ভ্যারিয়েবল ডিক্লেয়ার করলেন। এখন একই নামে যদি আরেকটা ভ্যারিয়েবল ডিক্লেয়ার করেন, সেটা কি জাভাস্ক্রিপ্ট মেনে নিবে? উত্তর হচ্ছে - নিবে আবার নিবে না! মানে? বুঝিয়ে বলছি —

যদি ভ্যারিয়েবলটি var দিয়ে ডিক্লেয়ার করেন তাহলে নিবে। আর যদি let অথবা const দিয়ে করেন তাহলে নিবে না। যেমনঃ

var job = "Engineer";
console.log(job); // output: Engineer

var job = "rikshwa calano"
console.log(job); // output: rikshwa calano

কোনো Error দেয় নাই, রাইট? এবার let দিয়ে ট্রাই করেন —

let gf = "Xadia";
console.log(gf); // output: "xadia";

let gf = "arekta";

এতটুকু রান করলেই সে ধরে বসবে - এই মিয়া কয়টা লাগে!! মানে, তার ভাষায় বললে -
Uncaught SyntaxError: Identifier 'gf' has already been declared

এভাবে const দিয়ে ডিক্লেয়ার করলেও একই এরর দিবে।

আচ্ছা, ডিক্লেয়ার এর কথা তো বুঝলাম কিন্তু reassign ( আপডেট ) করা যাবে? হ্যাঁ var আর let এর ক্ষেত্রে যাবে। তবে const এর ক্ষেত্রে যাবে না। যেমনঃ

let gf = "ex";
console.log(gf); // output: ex

gf = "present";
console.log(gf); // output: present

কোনো সমস্যা নেই তাই না? কিন্তু const দিয়ে try করে দেখেন —

const birthday = "29-08-2002";
console.log(birthday); // output: 29-08-2002

const birthday = "30-09-2003";

// Error ধরিয়ে দিবে - 
Uncaught TypeError: Assignment to constant variable.

মানে, কাজ হচ্ছে ২ টা - redeclaration ও reassignment । const কোনোটাই allow করে না। let একটা করে - reassignment । আর var দুইটাই করে।

কে কি allow করে, না করে বোঝা গেল। এবার তাদের সীমানা মাপা যাক —

Scope

Scope মানে সীমানা। সবকিছুরই একটা সীমানা থাকে। সো, জাভাস্ক্রিপ্টে variable কে access করারও সীমানা রয়েছে। তবে তা নির্ধারণ হয় তাকে কোন keyword দিয়ে declare করা হয়েছে তার উপর । JavaScript এ ৩ ধরণের scope রয়েছে -

১। Function Scope

২। Block Scope

৩। Global Scope

এর মধ্যে আজকের আলোচনায় শুধু ১ম দুইটা নিয়েই কথা বলব।

Function Scope

Function Scope বলতে বোঝায় তার মধ্যে লিখিত ভ্যারিয়েবলকে access করার সীমানা বা scope তার body-র মধ্যেই সীমাবদ্ধ। var ভ্যারিয়েবল Function Scoped । যেমন —

function a(){
    var text = "are paiba na";
}
// এখানে অর্থাৎ ফাংশনের বাহিরে `text` কে access করতে গেলে Error দিবে।

Block Scope

Block হচ্ছে curly braces { } দ্বারা আবদ্ধ জায়গা। এটা যেকোনো ১ জোড়া curly braces হতে পারে। if...else, for loop হতে পারে অথবা খালি { } ও হতে পারে।

let আর const ভ্যারিয়েবল Block Scoped

বোঝার সুবিধার্থে নিচে কিছু উদাহরণ দেওয়া হলো —

if(true){
    let success = "loading";
    var varVariable = "eito achi";
}
// `success`কে শুধু if এর curly braces এর ভিতরেই access করা যাবে।
// কিন্তু `varVariable` কে বাইরেও পাওয়া যাবে।

console.log(varVariable); // output: eito achi
{
    var hello = "hello";
    let isItAvailable = "don't know";
    const whatAboutConst = "same as let";
}

// {...} এর ভিতর লিখা ভ্যারিয়েবলগুলোকে যদি বাহিরে access করতে যাই, 
// তাহলে একমাত্র `hello`কেই পাওয়া যাবে। বাকি ২ টার ক্ষেত্রে Error দিবে।
function go(){
    let isGoing = true;
}
// `isGoing` কে ফাংশনের বাহিরে পাওয়া যাবে না।

এখানে দেখা যাচ্ছে let এবং const ভ্যারিয়েবলকেও ফাংশনের বাহিরে access করা যাচ্ছে না। তাই বলে তাদেরকে Function Scoped বলা যাবে না।

তো এই পর্যন্ত তাদের মধ্যে ২ টা পয়েন্টে মিল অমিল দেখলাম। এখন লাস্ট আরেকটা ছোট্ট পয়েন্টে তাদের পার্থক্য দেখে নেয়া যাক —

Hoisting

Hoisting মানে উপরে উঠানো। এখানে ভ্যারিয়েবলের ডিক্লেয়ারেশন উপরে উঠানো। আমরা জানি ভ্যারিয়েবল ডিক্লেয়ার করার পর তা access করা যায়। কিন্তু জাভাস্ক্রিপ্টের একটা ডিফল্ট বিহেভিয়র Hoisting। মানে ডিক্লেয়ার করার আগেই ভ্যারিয়েবল access করা যায়। তবে সব ভ্যারিয়েবল না, শুধুমাত্র var ভ্যারিয়েবল।

console.log(vobissot); // output: > ojana

var vobissot = "ojana";

‘use strict’ ব্যবহার করলে অবশ্য এই আচরণ বন্ধ করা যায়। সেটা বিষয় না। বিষয় হচ্ছে var সাথে let আর const এর এই জায়গায় তফাৎ আছে ।

একটু সামারি 🤏

var, let আর const এর মধ্যে ৩ টা পয়েন্টে পার্থক্য - রিঅ্যাসাইন ও রিডিক্লেয়ার করা, Scope এবং Hoisting। কোনো পয়েন্টে var ও let সিমিলার, কোনো পয়েন্টে let ও const সিমিলার। কিন্তু দিনশেষে ৩ টাই আলাদা।

এখন কাকে বানাবো আমার ভ্যারিয়েবলের Keyword? 🤔

যখন যাকে লাগে। যদি ভ্যারিয়েবলটা এমন হয় যে তাকে পরে reassign করতে হবে না তাহলে const

const birthday = "01-01-2002";
const pi = 3.1416;

আর যদি reassign করার মত হয় তাহলে let

let trend = "kichu ekta ghote geche";
let age = 20;

আর redeclare করার তো প্রয়োজনই পড়ে না। তাও যদি ইচ্ছা হয়, তাহলে scope এর বাহিরে করলেই চলে!

if(true){
    let gf = "Angela";
}

let gf = "Xadia";

var ব্যবহার করার কোনো দরকারই নাই। বরং ব্যবহার করলে মাঝে মধ্যে অনাকাঙ্খিত সমস্যা ও হতে পারে। তাই আমরা let ও const ই ব্যবহার করব।

var এত অপ্রয়োজনীয় হলে তাকে রাখছে কেন ? 🙄

আসলে vanilla JavaScript এ একমাত্র var ই আছে। বাকি দুই ভদ্রলোক ২০১৫ সালে আসা ES6 এর জিনিস। আমরা এখন যতই let ও const ব্যবহার করি না কেন ব্রাউজারের জাভাস্ক্রিপ্ট ইঞ্জিনের মাধ্যমে তা var এ-ই convert হয়।

শেষ পর্যন্ত স্ক্রল করার জন্য ধন্যবাদ 😀
আর হ্যাঁ, ভালো লাগলে লাইক-কমেন্ট করে উৎসাহিত করবেন 😊

9
Subscribe to my newsletter

Read articles from Mahfuz Swaron directly inside your inbox. Subscribe to the newsletter, and don't miss out.

Written by

Mahfuz Swaron
Mahfuz Swaron

An ordinary web developer with extra-ordinary teaching skill. It's not my own speech, I often hear this appreciation from the people around me. By the way, I am a student of Computer Technology department in a Govt. Polytechnic Institute. Currently in 7th semester (out of 8). I have learnt MERN Stack and related technologies and built many web applications. You may browse them from my GitHub profile or portfolio website.