ভেরিয়েবল

ভেরিয়েবল হল একটি ডেটা স্ট্রাকচার যা একটি মানের প্রতিনিধির নাম নির্ধারণ করে। তারা যে কোনো ধরনের তথ্য ধারণ করতে পারে.

একটি ভেরিয়েবলের নামকে একটি শনাক্তকারী বলা হয়। একজন বৈধ শনাক্তকারীকে অবশ্যই এই নিয়মগুলি অনুসরণ করতে হবে:

  • শনাক্তকারীতে ইউনিকোড অক্ষর, ডলার চিহ্ন ($), আন্ডারস্কোর অক্ষর (_), সংখ্যা (0-9) এবং এমনকি কিছু ইউনিকোড অক্ষর থাকতে পারে।
  • শনাক্তকারীরা হোয়াইটস্পেস ধারণ করতে পারে না, কারণ পার্সার ইনপুট উপাদানগুলিকে আলাদা করতে হোয়াইটস্পেস ব্যবহার করে। উদাহরণস্বরূপ, যদি আপনি myVariable এর পরিবর্তে একটি ভেরিয়েবলকে my Variable বলার চেষ্টা করেন, পার্সার দুটি শনাক্তকারী, my এবং Variable দেখতে পায় এবং একটি সিনট্যাক্স ত্রুটি ("অপ্রত্যাশিত টোকেন: সনাক্তকারী") নিক্ষেপ করে।
  • শনাক্তকারীকে অবশ্যই একটি অক্ষর, আন্ডারস্কোর ( _ ), বা ডলার চিহ্ন ( $ ) দিয়ে শুরু করতে হবে। সংখ্যা এবং শনাক্তকারীর মধ্যে বিভ্রান্তি রোধ করতে তারা সংখ্যা দিয়ে শুরু করতে পারে না:

    let 1a = true;
    
    > Uncaught SyntaxError: Invalid or unexpected token
    

    যদি জাভাস্ক্রিপ্ট একটি শনাক্তকারীর শুরুতে নম্বরগুলিকে অনুমতি দেয়, তাহলে এটি শুধুমাত্র সংখ্যা দিয়ে তৈরি শনাক্তকারীকে অনুমতি দেবে, যা সংখ্যা হিসাবে ব্যবহৃত সংখ্যা এবং শনাক্তকারী হিসাবে ব্যবহৃত সংখ্যাগুলির মধ্যে দ্বন্দ্ব সৃষ্টি করবে:

    let 10 = 20
    
    10 + 5
    > ?
    
  • " সংরক্ষিত শব্দ " যেগুলি ইতিমধ্যেই সিনট্যাক্টিক্যালি অর্থপূর্ণ সেগুলি সনাক্তকারী হিসাবে ব্যবহার করা যাবে না৷

  • আইডেন্টিফায়ারে বিশেষ অক্ষর থাকতে পারে না ( ! . , / \ + - * = )।

নিম্নলিখিতগুলি শনাক্তকারী তৈরি করার জন্য কঠোর নিয়ম নয়, তবে এগুলি হল শিল্পের সেরা অনুশীলন যা আপনার কোড বজায় রাখা সহজ করে তোলে৷ যদি আপনার নির্দিষ্ট প্রকল্পের বিভিন্ন মান থাকে, তাহলে ধারাবাহিকতার জন্য সেগুলি অনুসরণ করুন।

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

let camelCasedIdentifier = true;

কিছু প্রকল্প প্রসঙ্গ এবং ডেটার প্রকৃতির উপর নির্ভর করে অন্যান্য নামকরণ প্রথা ব্যবহার করে। উদাহরণস্বরূপ, একটি ক্লাসের প্রথম অক্ষরটি সাধারণত বড় আকারের হয়, তাই বহু-শব্দ শ্রেণির নামগুলি প্রায়শই উটের কেসের একটি বৈকল্পিক ব্যবহার করে যা সাধারণত "আপার ক্যামেল কেস" বা প্যাসকেল কেস বলে।

class MyClass {

}

আইডেন্টিফায়ারদের তাদের থাকা ডেটার প্রকৃতি সংক্ষিপ্তভাবে বর্ণনা করা উচিত (উদাহরণস্বরূপ, theNumberOfDaysInTheCurrentMonth এর চেয়ে currentMonthDays একটি ভাল নাম) এবং এক নজরে স্পষ্টভাবে পড়ুন ( originalValue val এর চেয়ে ভাল)। এই মডিউল জুড়ে ব্যবহৃত myVariable আইডেন্টিফায়ারগুলি বিচ্ছিন্ন উদাহরণের প্রেক্ষাপটে কাজ করে, কিন্তু প্রোডাকশন কোডে খুব অসহায় হবে কারণ তারা কী ডেটা রয়েছে সে সম্পর্কে কোনও তথ্য দেয় না।

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

জাভাস্ক্রিপ্ট আন্ডারস্কোর অক্ষর ( _ ) দিয়ে শুরু হওয়া শনাক্তকারীদের কোন বিশেষ সুবিধা বা অর্থ দেয় না, তবে তারা সাধারণত এটি দেখানোর জন্য ব্যবহার করা হয় যে একটি পরিবর্তনশীল, পদ্ধতি বা সম্পত্তি "ব্যক্তিগত", যার অর্থ এটি শুধুমাত্র ভিতরে ব্যবহারের জন্য উদ্দেশ্যে করা হয়েছে অবজেক্টের প্রেক্ষাপট যা এটি ধারণ করে এবং সেই প্রসঙ্গের বাইরে অ্যাক্সেস বা পরিবর্তন করা উচিত নয়। এটি একটি কনভেনশন যা অন্যান্য প্রোগ্রামিং ল্যাঙ্গুয়েজ থেকে সম্পাদিত হয় এবং জাভাস্ক্রিপ্টের প্রাইভেট প্রপার্টি যোগ করার পূর্ববর্তী।

পরিবর্তনশীল ঘোষণা

একটি শনাক্তকারী সম্পর্কে জাভাস্ক্রিপ্টকে সচেতন করার একাধিক উপায় রয়েছে, একটি প্রক্রিয়া যাকে একটি পরিবর্তনশীল "ঘোষণা" বলা হয়। let , const , বা var কীওয়ার্ড ব্যবহার করে একটি ভেরিয়েবল ঘোষণা করা হয়।

let myVariable;

যে কোনো সময় পরিবর্তন করা যেতে পারে এমন একটি ভেরিয়েবল ঘোষণা করতে let বা var ব্যবহার করুন। এই কীওয়ার্ডগুলি জাভাস্ক্রিপ্ট ইন্টারপ্রেটারকে বলে যে অক্ষরের একটি স্ট্রিং একটি শনাক্তকারী যা একটি মান থাকতে পারে।

একটি আধুনিক কোডবেসে কাজ করার সময়, var এর পরিবর্তে let ব্যবহার করুন। var এখনও আধুনিক ব্রাউজারগুলিতে কাজ করে, তবে এর কিছু অজ্ঞাত আচরণ রয়েছে যা জাভাস্ক্রিপ্টের প্রথমতম সংস্করণগুলিতে সংজ্ঞায়িত করা হয়েছিল এবং তারপরে পিছনের সামঞ্জস্য রক্ষা করার জন্য পরে পরিবর্তন করা যায়নি। var এর ডিজাইনের সাথে কিছু সমস্যা সমাধানের জন্য ES6 এ যোগ করা let

একটি ঘোষিত ভেরিয়েবলকে ভেরিয়েবলের একটি মান নির্ধারণ করে শুরু করা হয়। একটি ভেরিয়েবলের মান নির্ধারণ বা পুনরায় বরাদ্দ করতে একটি একক সমান চিহ্ন ( = ) ব্যবহার করুন। আপনি একই বিবৃতির অংশ হিসাবে এটি করতে পারেন যা এটি ঘোষণা করে:

let myVariable = 5;

myVariable + myVariable
> 10

আপনি এখনই শুরু না করে let (বা var ) দিয়ে একটি ভেরিয়েবল ঘোষণা করতে পারেন। যদি আপনি তা করেন, আপনার কোড এটিকে একটি মান নির্ধারণ না করা পর্যন্ত ভেরিয়েবলের প্রাথমিক মানটি undefined থাকে।

let myVariable;

myVariable;
> undefined

myVariable = 5;

myVariable + myVariable
> 10

একটি undefined মান সহ একটি পরিবর্তনশীল একটি অনির্ধারিত ভেরিয়েবল থেকে আলাদা যার শনাক্তকারী এখনও ঘোষণা করা হয়নি৷ আপনি ঘোষণা করেননি এমন একটি পরিবর্তনশীল উল্লেখ করা একটি ত্রুটির কারণ।

myVariable
> Uncaught ReferenceError: myVariable is not defined

let myVariable;

myVariable
> undefined

একটি মানের সাথে একটি শনাক্তকারীর সংযোগকে সাধারণত "বাইন্ডিং" বলা হয়। সিনট্যাক্স যেটি let , var , বা const কীওয়ার্ড অনুসরণ করে তাকে "বাইন্ডিং তালিকা" বলা হয় এবং এটি একাধিক কমা-বিভাজিত পরিবর্তনশীল ঘোষণার অনুমতি দেয় (প্রত্যাশিত সেমিকোলন দিয়ে শেষ হয়)। এটি নিম্নলিখিত কোড স্নিপেটগুলিকে কার্যকরীভাবে অভিন্ন করে তোলে:

let firstVariable,
     secondVariable,
     thirdVariable;
let firstVariable;
let secondVariable;
let thirdVariable;

একটি ভেরিয়েবলের মান পুনরায় বরাদ্দ করা let (বা var ) ব্যবহার করে না, কারণ জাভাস্ক্রিপ্ট ইতিমধ্যেই জানে যে ভেরিয়েবলটি বিদ্যমান:

let myVariable = true;

myVariable
> true

myVariable = false;

myVariable
> false

আপনি তাদের বিদ্যমান মানগুলির উপর ভিত্তি করে ভেরিয়েবলগুলিকে নতুন মানগুলি পুনরায় বরাদ্দ করতে পারেন:

let myVariable = 10;

myVariable
> 10

myVariable = myVariable * myVariable;

myVariable
> 100

আপনি একটি উত্পাদন পরিবেশে let ব্যবহার করে একটি পরিবর্তনশীল পুনরায় ঘোষণা করার চেষ্টা করলে, আপনি একটি সিনট্যাক্স ত্রুটি পাবেন:

let myVariable = true;
let myVariable = false;
> Uncaught SyntaxError: redeclaration of let myVariable

ব্রাউজারগুলির বিকাশকারী সরঞ্জামগুলি let (এবং class ) পুনঃঘোষণা সম্পর্কে আরও অনুমোদিত, তাই আপনি আপনার বিকাশকারী কনসোলে একই ত্রুটি দেখতে পাবেন না।

লিগ্যাসি ব্রাউজার সামঞ্জস্য রক্ষা করার জন্য, var কোনো প্রেক্ষাপটে ত্রুটি ছাড়াই অপ্রয়োজনীয় পুনরায় ঘোষণার অনুমতি দেয়:

var myVariable = true;
var myVariable = false;

myVariable\
> false

const

একটি ধ্রুবক ঘোষণা করতে const কীওয়ার্ড ব্যবহার করুন, একটি ভেরিয়েবলের একটি প্রকার যা অবিলম্বে শুরু করা আবশ্যক, এবং তারপর পরিবর্তন করা যাবে না। ধ্রুবকের শনাক্তকারীরা let (এবং var ) ব্যবহার করে ঘোষিত ভেরিয়েবলের মতো একই নিয়ম অনুসরণ করে।

const myConstant = true;

myConstant
> true

আপনি অবিলম্বে একটি মান বরাদ্দ না করে একটি ধ্রুবক ঘোষণা করতে পারবেন না, কারণ ধ্রুবকগুলি তৈরি হওয়ার পরে পুনরায় বরাদ্দ করা যায় না, তাই যেকোনো অপ্রবর্তিত ধ্রুবক চিরকালের জন্য undefined থাকবে। আপনি যদি এটি শুরু না করে একটি ধ্রুবক ঘোষণা করার চেষ্টা করেন তবে আপনি একটি সিনট্যাক্স ত্রুটি পাবেন:

const myConstant;
Uncaught SyntaxError: missing = in const declaration

const দিয়ে ঘোষিত একটি ভেরিয়েবলের মান পরিবর্তন করার চেষ্টা করার ফলে আপনি let (বা var ) দিয়ে ঘোষিত একটি ভেরিয়েবলের মান পরিবর্তন করতে পারেন একটি টাইপ ত্রুটির কারণ:

const myConstant = true;

myConstant = false;
> Uncaught TypeError: invalid assignment to const 'myConstant'

যাইহোক, যখন একটি ধ্রুবক একটি বস্তুর সাথে যুক্ত হয়, তখন সেই বস্তুর বৈশিষ্ট্যগুলি পরিবর্তন করা যেতে পারে

const constantObject = { "firstvalue" : true };

constantObject
> Object { firstvalue: true }

constantObject.secondvalue = false;

constantObject
> Object { firstvalue: true, secondvalue: false }

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

const constantObject = { "firstvalue" : true };

constantObject = false
> Uncaught TypeError: invalid assignment to const 'constantObject'

যখন আপনি একটি ভেরিয়েবলকে পুনরায় বরাদ্দ করার আশা করেন না, তখন এটি একটি ধ্রুবক তৈরি করা সর্বোত্তম অনুশীলন। const ব্যবহার করা আপনার ডেভেলপমেন্ট টিম বা প্রোজেক্টের ভবিষ্যত রক্ষণাবেক্ষণকারীদের বলে যে সেই মানটি পরিবর্তন না করতে, আপনার কোড কীভাবে এটি ব্যবহার করা হয় সে সম্পর্কে অনুমানগুলি ভাঙতে না পারে—উদাহরণস্বরূপ, একটি ভেরিয়েবল শেষ পর্যন্ত একটি প্রত্যাশিত ডেটা টাইপের বিরুদ্ধে মূল্যায়ন করা হবে।

পরিবর্তনশীল সুযোগ

একটি ভেরিয়েবলের সুযোগ হল একটি স্ক্রিপ্টের অংশ যেখানে সেই ভেরিয়েবলটি পাওয়া যায়। একটি ভেরিয়েবলের সুযোগের বাইরে, এটি সংজ্ঞায়িত করা হবে না - একটি undefined মান ধারণকারী একটি শনাক্তকারী হিসাবে নয়, তবে যেন এটি ঘোষণা করা হয়নি৷

একটি ভেরিয়েবল ঘোষণা করার জন্য আপনি যে কীওয়ার্ড ব্যবহার করেন এবং যে প্রেক্ষাপটে আপনি এটিকে সংজ্ঞায়িত করেন তার উপর নির্ভর করে, আপনি স্টেটমেন্ট ( ব্লক স্কোপ ), স্বতন্ত্র ফাংশন ( ফাংশন স্কোপ ) বা সম্পূর্ণ জাভাস্ক্রিপ্ট অ্যাপ্লিকেশন ( গ্লোবাল স্কোপ ) ব্লক করতে স্কোপ ভেরিয়েবল ব্যবহার করতে পারেন।

ব্লক সুযোগ

let বা const ব্যবহার করে আপনি যে ভেরিয়েবল ডিক্লেয়ার করেন তার সবথেকে কাছাকাছি থাকা ব্লক স্টেটমেন্টে স্কোপ করা হয়, যার মানে ভেরিয়েবলটি শুধুমাত্র সেই ব্লকের মধ্যেই অ্যাক্সেস করা যায়। একটি ব্লক স্কোপড ভেরিয়েবল অ্যাক্সেস করার চেষ্টা করার চেষ্টা করা ব্লকের বাইরে একটি ভেরিয়েবল অ্যাক্সেস করার চেষ্টা করার মতো একই ত্রুটি সৃষ্টি করে যা বিদ্যমান নেই:

{
    let scopedVariable = true;
    console.log( scopedVariable );
}
> true

scopedVariable
> ReferenceError: scopedVariable is not defined

যতদূর জাভাস্ক্রিপ্ট উদ্বিগ্ন, একটি ব্লক স্কোপড ভেরিয়েবল ব্লকের বাইরে বিদ্যমান নেই যা এটি ধারণ করে। উদাহরণস্বরূপ, আপনি একটি ব্লকের ভিতরে একটি ধ্রুবক ঘোষণা করতে পারেন এবং তারপর সেই ব্লকের বাইরে অন্য একটি ধ্রুবক ঘোষণা করতে পারেন যা একই শনাক্তকারী ব্যবহার করে:

{
  const myConstant = false;
}
const myConstant = true;

scopedConstant;
> true

যদিও একটি ঘোষিত ভেরিয়েবল তার মূল ব্লকের মধ্যে প্রসারিত করতে পারে না, এটি সমস্ত বংশধর ব্লকের জন্য উপলব্ধ :

{
    let scopedVariable = true;
    {
    console.log( scopedVariable );
    }
}
> true

একটি ঘোষিত ভেরিয়েবলের মান একটি বংশধর ব্লকের মধ্যে থেকে পরিবর্তন করা যেতে পারে:

{
    let scopedVariable = false;
    {
    scopedVariable = true;
    }
    console.log( scopedVariable );
}
> true

একটি নতুন ভেরিয়েবল ত্রুটি ছাড়াই একটি বংশধর ব্লকের ভিতরে let বা const দিয়ে আরম্ভ করা যেতে পারে, এমনকি যদি এটি একটি অভিভাবক ব্লকে একটি পরিবর্তনশীল হিসাবে একই শনাক্তকারী ব্যবহার করে:

{
    let scopedVariable = false;
    {
    let scopedVariable = true;
    }
    console.log( scopedVariable );
}
> false

ফাংশন স্কোপ

var ব্যবহার করে ঘোষিত ভেরিয়েবলগুলি তাদের নিকটতম ধারণকারী ফাংশন (অথবা একটি ক্লাসের ভিতরে স্ট্যাটিক ইনিশিয়ালাইজেশন ব্লক ) স্কোপ করা হয়।

function myFunction() {
    var scopedVariable = true;

    return scopedVariable;
}

scopedVariable;
> ReferenceError: scopedVariable is not defined

একটি ফাংশন কল করার পরেও এটি রয়েছে। যদিও ফাংশনটি কার্যকর করার সময় ভেরিয়েবলটি আরম্ভ করা হয়, সেই ভেরিয়েবলটি এখনও ফাংশনের সুযোগের বাইরে অনুপলব্ধ:

function myFunction() {
    var scopedVariable = true;

    return scopedVariable;
}

scopedVariable;
> ReferenceError: scopedVariable is not defined

myFunction();
> true

scopedVariable;
> ReferenceError: scopedVariable is not defined

বিশ্বব্যাপী সুযোগ

একটি গ্লোবাল ভেরিয়েবল একটি সম্পূর্ণ জাভাস্ক্রিপ্ট অ্যাপ্লিকেশন জুড়ে উপলব্ধ, যেকোনো এবং সমস্ত ব্লক এবং ফাংশনের ভিতরে, পৃষ্ঠার যেকোনো স্ক্রিপ্টে।

যদিও এটি একটি পছন্দসই ডিফল্ট বলে মনে হতে পারে, একটি অ্যাপ্লিকেশনের যেকোনো অংশ অ্যাক্সেস এবং পরিবর্তন করতে পারে এমন ভেরিয়েবলগুলি অপ্রয়োজনীয় ওভারহেড যোগ করতে পারে, অথবা একই শনাক্তকারী সহ একটি অ্যাপ্লিকেশনের অন্য কোথাও ভেরিয়েবলের সাথে সংঘর্ষের কারণ হতে পারে। এটি তৃতীয় পক্ষের লাইব্রেরি এবং ব্যবহারকারী বিশ্লেষণের মতো জিনিসগুলি সহ একটি পৃষ্ঠার রেন্ডারিংয়ের সাথে জড়িত যে কোনও এবং সমস্ত জাভাস্ক্রিপ্টের ক্ষেত্রে প্রযোজ্য৷ অতএব, যখনই সম্ভব বিশ্বব্যাপী সুযোগকে দূষিত করা এড়াতে এটি সর্বোত্তম অনুশীলন।

প্যারেন্ট ফাংশনের বাইরে var ব্যবহার করে বা প্যারেন্ট ব্লকের বাইরে let বা const ব্যবহার করে ঘোষিত যেকোনো ভেরিয়েবল বিশ্বব্যাপী:

var functionGlobal = true; // Global
let blockGlobal = true; // Global

{
    console.log( blockGlobal );
    console.log( functionGlobal );
}
> true
> true

(function() {
    console.log( blockGlobal );
    console.log( functionGlobal );
}());
> true
> true

একটি ভেরিয়েবলকে স্পষ্টভাবে ঘোষণা না করে একটি মান বরাদ্দ করা (অর্থাৎ এটি তৈরি করতে var , let , বা const ব্যবহার না করে) একটি ভেরিয়েবলকে বৈশ্বিক সুযোগে উন্নীত করে, এমনকি যখন একটি ফাংশন বা ব্লকের ভিতরে শুরু করা হয়। এই প্যাটার্ন ব্যবহার করে তৈরি একটি পরিবর্তনশীলকে কখনও কখনও "উহ্য বিশ্ব" বলা হয়।

function myFunction() {
    globalVariable = "global";

    return globalVariable
}

myFunction()\
> "global"

globalVariable\
> "global"

পরিবর্তনশীল উত্তোলন

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

hoistedVariable
> undefined

var hoistedVariable;

কারণ শুধুমাত্র ভেরিয়েবল ডিক্লেয়ারেশন হোস্ট করা হয়, ইনিশিয়ালাইজেশন নয়, যে ভেরিয়েবলগুলি var , let , বা const দিয়ে স্পষ্টভাবে ঘোষণা করা হয়নি সেগুলি হোস্ট করা হয় না:

unhoistedVariable;
> Uncaught ReferenceError: unhoistedVariable is not defined

unhoistedVariable = true;

পূর্বে উল্লিখিত হিসাবে , একটি ঘোষিত কিন্তু অপ্রবর্তিত ভেরিয়েবলকে undefined একটি মান বরাদ্দ করা হয়। এই আচরণটি উত্তোলিত পরিবর্তনশীল ঘোষণার ক্ষেত্রেও প্রযোজ্য, তবে শুধুমাত্র var ব্যবহার করে ঘোষিতদের ক্ষেত্রে।

hoistedVariable
> undefined

var hoistedVariable = 2 + 2;

hoistedVariable\
> 4

এই অজ্ঞাত আচরণটি মূলত জাভাস্ক্রিপ্টের প্রথমতম সংস্করণে করা ডিজাইনের সিদ্ধান্তগুলির একটি হোল্ডওভার, এবং বিদ্যমান সাইটগুলি ভাঙার ঝুঁকি ছাড়া পরিবর্তন করা যাবে না।

let এবং const পরিবর্তে একটি ত্রুটি ছুঁড়ে দিয়ে এই আচরণের সমাধান করুন যখন একটি ভেরিয়েবল তৈরি হওয়ার আগে এটি অ্যাক্সেস করা হয়:

{
    hoistedVariable;

    let hoistedVariable;
}
> Uncaught ReferenceError: can't access lexical declaration 'hoistedVariable' before initialization

এই ত্রুটিটি "hoistedVariable is not defined" ত্রুটি থেকে ভিন্ন যা আপনি একটি অঘোষিত পরিবর্তনশীল অ্যাক্সেস করার চেষ্টা করার সময় আশা করতে পারেন। যেহেতু জাভাস্ক্রিপ্ট ভেরিয়েবলটি উত্তোলন করেছে, এটি সচেতন যে প্রদত্ত সুযোগের মধ্যে ভেরিয়েবলটি তৈরি করা হবে। যাইহোক, undefined এর মান সহ ঘোষণার আগে সেই পরিবর্তনশীলটিকে উপলব্ধ করার পরিবর্তে, দোভাষী একটি ত্রুটি ছুড়ে দেয়। let বা const (বা class ) দিয়ে ঘোষিত ভেরিয়েবলগুলিকে বলা হয় "টেম্পোরাল ডেড জোন" ("TDZ") তাদের এনক্লোজিং ব্লকের শুরু থেকে কোডের বিন্দু পর্যন্ত যেখানে ভেরিয়েবল ঘোষণা করা হয়েছে।

টেম্পোরাল ডেড জোন লেখকদের জন্য var চেয়ে let এর আচরণকে আরও বেশি স্বজ্ঞাত করে তোলে। এটি const এর ডিজাইনের জন্যও গুরুত্বপূর্ণ। যেহেতু ধ্রুবক পরিবর্তন করা যায় না, একটি ধ্রুবককে তার সুযোগের শীর্ষে উত্তোলন করা হয় এবং undefined একটি অন্তর্নিহিত মান দেওয়া হয় তখন একটি অর্থপূর্ণ মান দিয়ে আরম্ভ করা যায় না।

আপনার উপলব্ধি পরীক্ষা করুন

আপনি কি ধরনের অক্ষর দিয়ে একটি শনাক্তকারী শুরু করতে পারেন?

একটি চিঠি
একটি আন্ডারস্কোর
একটি অঙ্ক

একটি পরিবর্তনশীল ঘোষণা করার পছন্দের পদ্ধতি কোনটি যার মান যেকোনো সময় পরিবর্তন করা যেতে পারে?

যাক
const
var