জাভাস্ক্রিপ্টে ক্লাসগুলির অতিরিক্ত বৈশিষ্ট্য

জাভাস্ক্রিপ্টে ক্লাসগুলির অতিরিক্ত বৈশিষ্ট্য

এই নিবন্ধে, আমরা জাভাস্ক্রিপ্টে ক্লাসগুলির অতিরিক্ত বৈশিষ্ট্যগুলি ব্যাখ্যা করব।

YouTube Video

জাভাস্ক্রিপ্টে ক্লাসগুলির অতিরিক্ত বৈশিষ্ট্য

জাভাস্ক্রিপ্টে ব্যক্তিগত প্রোপার্টি

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

ECMAScript 2020 (ES11), যা ২০২০ সালে প্রবর্তিত হয়েছিল, সেখানে ক্লাসের ভিতরে ব্যক্তিগত ফিল্ড সংজ্ঞায়িত করার জন্য # ব্যবহারের ব্যবস্থা চালু করা হয়েছে। এটি প্রচলিত জাভাস্ক্রিপ্ট ব্যক্তিগত কনভেনশন (যেমন: আন্ডারস্কোর দিয়ে শুরু হওয়া ভেরিয়েবল নাম) অপেক্ষা আরও স্পষ্ট একটি পদ্ধতি প্রদান করে। এটি আরও স্বচ্ছ একটি পদ্ধতি প্রদান করে, যা জাভাস্ক্রিপ্টের ঐতিহ্যগত ব্যক্তিগত কনভেনশনগুলিকে (যেমন আন্ডারস্কোর দিয়ে শুরু হওয়া ভেরিয়েবল নাম) প্রতিস্থাপন করে।

ব্যক্তিগত প্রোপার্টিগুলি কীভাবে ব্যবহার করবেন

ক্লাসে ব্যক্তিগত প্রোপার্টি সংজ্ঞায়িত করা

ব্যক্তিগত ফিল্ডগুলি # দিয়ে শুরু করা একটি নাম ব্যবহার করে সংজ্ঞায়িত করা হয়। এই ফিল্ডটি ক্লাস বা তার সাবক্লাসগুলির ইনস্ট্যান্স থেকে সরাসরি অ্যাক্সেস করা যায় না।

 1class Person {
 2    // Define private property
 3    #name;
 4
 5    constructor(name) {
 6        this.#name = name;
 7    }
 8
 9    // Method to access the private property
10    getName() {
11        return this.#name;
12    }
13
14    // Method to change the private property
15    setName(newName) {
16        this.#name = newName;
17    }
18}
19
20const john = new Person("John");
21console.log(john.getName()); // John

উপরের কোডে, #name একটি ব্যক্তিগত প্রোপার্টি যা Person ক্লাসের বাইরে থেকে সরাসরি অ্যাক্সেস করা যায় না। আপনি শুধুমাত্র getName এবং setName পদ্ধতিগুলির মাধ্যমে নাম অ্যাক্সেস বা পরিবর্তন করতে পারেন।

1// Cannot access private property directly
2console.log(john.#name); // SyntaxError: Private field '#name' must be declared in an enclosing class

ব্যক্তিগত মেথড সংজ্ঞায়িত করা

ব্যক্তিগত প্রোপার্টির মতো, ব্যক্তিগত মেথডগুলিও # দিয়ে শুরু করা নাম ব্যবহার করে সংজ্ঞায়িত করা হয়। ব্যক্তিগত মেথড শুধুমাত্র ক্লাসের ভিতর থেকে ডাকা যেতে পারে।

 1class Counter {
 2    #count = 0;
 3
 4    increment() {
 5        this.#count++;
 6        this.#logCount(); // Calling private method
 7    }
 8
 9    // Private method
10    #logCount() {
11        console.log(`Current count: ${this.#count}`);
12    }
13}
14
15const counter = new Counter();
16counter.increment(); // Current count: 1

এখানে, #logCount একটি ব্যক্তিগত মেথড হিসেবে সংজ্ঞায়িত করা হয়েছে এবং এটি ক্লাসের বাইরে থেকে অ্যাক্সেস করা যায় না। এই মেথডটি শুধুমাত্র ক্লাসের ভিতরেই ব্যবহৃত হয়।

1// Cannot access private method directly
2counter.#logCount(); // SyntaxError: Private field '#logCount' must be declared in an enclosing class

ব্যক্তিগত প্রোপার্টির সুবিধা ও বিবেচনা

সুবিধা

  • এনক্যাপসুলেশন: বাহ্যিক দৃষ্টিভঙ্গি থেকে অভ্যন্তরীণ অবস্থা লুকিয়ে রাখে এবং তথ্যের সামঞ্জস্য বজায় রাখে।
  • নিরাপত্তা: বাহ্যিক কোড দ্বারা প্রোপার্টিগুলি অসতর্কতার সাথে পরিবর্তন হওয়া থেকে প্রতিরোধ করে।
  • উন্নত রক্ষণাবেক্ষণক্ষমতা: অবজেক্ট বা ক্লাসের বাস্তবায়ন লুকিয়ে রাখে এবং বাহ্যিকভাবে উন্মুক্ত ইন্টারফেসটি স্পষ্ট করে তোলে।

নোটস

  • প্রাইভেট ফিল্ডগুলো ক্লাসের বাইরে থেকে সম্পূর্ণ লুকানো থাকে বলে টেস্টিং এবং ডিবাগিং কঠিন হতে পারে। সুতরাং, এমন একটি API প্রদান করা গুরুত্বপূর্ণ যা ডিজাইন পর্যায়ে সম্পূর্ণরূপে টেস্ট করা যায়।
  • প্রাইভেট ফিল্ডগুলো প্রোটোটাইপ ভিত্তিক বৈশিষ্ট্যসহ জাভাস্ক্রিপ্টের অন্যান্য অংশ থেকে ভিন্ন আচরণ করে কারণ এগুলো প্রতিটি ইনস্ট্যান্সের জন্য অনন্য।

প্রাইভেট প্রপার্টির ঐতিহ্যবাহী ছদ্মনামযুক্ত বাস্তবায়ন

# ব্যবহার করে প্রাইভেট ফিল্ড প্রবর্তনের আগে, জাভাস্ক্রিপ্টে প্রাইভেট প্রপার্টির জন্য কোনও আনুষ্ঠানিক সিনট্যাক্স ছিল না। তাই, অতীতে ছদ্ম-প্রাইভেট প্রপার্টিগুলো নিচের উপায়ে বাস্তবায়িত হয়েছিল।

আন্ডারস্কোর ব্যবহার করার প্রচলন

ডেভেলপাররা প্রচলিতভাবে ভ্যারিয়েবল নামের শুরুতে আন্ডারস্কোর বসিয়ে 'প্রাইভেট' নির্দেশ করতেন।

 1class Car {
 2    constructor(brand) {
 3        this._brand = brand; // Using an underscore to indicate private
 4    }
 5
 6    getBrand() {
 7        return this._brand;
 8    }
 9}
10
11const car = new Car("Toyota");
12console.log(car.getBrand()); // Toyota
13console.log(car._brand); // Toyota (Accessible from outside)

এই পদ্ধতিটি কেবল একটি 'প্রচলন,' এবং বাস্তবে, প্রপার্টিগুলো এখনও বাইরে থেকে অ্যাক্সেসযোগ্য থাকে।

ক্লোজার ব্যবহার করে প্রাইভেট প্রপার্টি বাস্তবায়ন

ফাংশনের স্কোপে ক্লোজার ব্যবহার করেও প্রাইভেট প্রপার্টি অর্জন করা সম্ভব।

 1function createPerson(name) {
 2    let _name = name; // Private variable within function scope
 3
 4    return {
 5        getName: function() {
 6            return _name;
 7        },
 8        setName: function(newName) {
 9            _name = newName;
10        }
11    };
12}
13
14const person = createPerson("Alice");
15console.log(person.getName()); // Alice
16person.setName("Bob");
17console.log(person.getName()); // Bob
18
19// Cannot access directly from outside
20console.log(person._name); // undefined

এই পদ্ধতিতে, ভ্যারিয়েবল _name ফাংশন স্কোপের মধ্যে আবদ্ধ থাকে এবং বাইরে থেকে সরাসরি অ্যাক্সেস করা যায় না।

সারসংক্ষেপ

জাভাস্ক্রিপ্টে প্রাইভেট প্রপার্টি ক্লাস এবং অবজেক্ট ডিজাইনে ইনক্যাপসুলেশন প্রদান করতে অত্যন্ত কার্যকর, যা ডেটা নিরাপদে সংরক্ষণে সহায়তা করে। ES2020 এ প্রাইভেট ফিল্ডের জন্য প্রবর্তিত # নোটেশন প্রচলিত পদ্ধতি এবং ক্লোজারের তুলনায় স্পষ্ট এবং আরও নিরাপদ গোপনীয়তা ব্যবস্থাপনা প্রদান করে।

জাভাস্ক্রিপ্টে ঐচ্ছিক চেইনিং

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

ঐচ্ছিক চেইনিংয়ের মৌলিক সিনট্যাক্স

? চিহ্নটি প্রপার্টি অ্যাক্সেস করার জন্য ব্যবহৃত . বা ব্র্যাকেট নোটেশনের আগে বসিয়ে অপশনাল চেইনিং ব্যবহার করা যায়। এই নোটেশনটি null বা undefined প্রোপার্টি আসলে undefined রিটার্ন করে, যা প্রোগ্রামকে কোনও ত্রুটি ছাড়াই সুরক্ষিতভাবে প্রসেস চালিয়ে যেতে দেয়।

উদাহরণ:

 1const user = {
 2    name: 'John',
 3    address: {
 4        street: '123 Main St',
 5        city: 'New York'
 6    }
 7};
 8
 9// Without using optional chaining
10const city = user && user.address && user.address.city;
11console.log(city);  // New York
12
13// Using optional chaining
14const cityWithOptionalChaining = user?.address?.city;
15console.log(cityWithOptionalChaining);  // New York

এই উদাহরণে, আমরা user অবজেক্টের address এবং তার city প্রোপার্টি অ্যাক্সেস করছি। ঐচ্ছিক চেনিং ব্যবহার না করলে, আপনাকে একাধিক অস্তিত্ব পরীক্ষা করতে হবে, কিন্তু ঐচ্ছিক চেনিং এর মাধ্যমে একটি একক বিবৃতি ব্যবহার করেই সম্পত্তিতে নিরাপদে প্রবেশ করতে পারেন।

এরে এবং ফাংশনের সাথে ঐচ্ছিক চেনিং ব্যবহার

ঐচ্ছিক চেনিং কেবলমাত্র অবজেক্টের সম্পত্তির জন্য নয়, এরে উপাদান এবং ফাংশন কলের জন্যও প্রযোজ্য।

এরে সহ উদাহরণঃ

1const users = [{ name: 'Alice' }, { name: 'Bob' }];
2
3// Accessing the non-existent third element
4const thirdUser = users[2]?.name;
5console.log(thirdUser);  // undefined
  • এইভাবে, আপনি অপশনাল চেইনিং ব্যবহার করে অ্যারে উপাদানগুলিতেও অ্যাক্সেস করতে পারেন।

ফাংশন সহ উদাহরণঃ

 1const user = {
 2    greet: function() {
 3        return 'Hello!';
 4    }
 5};
 6
 7// Call the function only if greet exists
 8const greeting = user.greet?.();
 9console.log(greeting);  // Hello!
10
11// Return undefined if greet does not exist
12const nonExistentGreeting = user.nonExistentMethod?.();
13console.log(nonExistentGreeting);  // undefined
  • এই উদাহরণে দেখানো হয়েছে, এটি ফাংশন কলের ক্ষেত্রেও প্রয়োগ করা যেতে পারে।

ঐচ্ছিক চেনিং এবং ডিফল্ট মানের সংমিশ্রণ

ঐচ্ছিক চেনিং ব্যবহার করার সময়, ডিফল্ট মান নির্ধারণের জন্য সাধারণত লজিকাল OR (||) বা নালিশ কোয়েলাসিং অপারেটর (??) ব্যবহার করা হয় যখন কোনও সম্পত্তি বিদ্যমান না থাকে।

উদাহরণ:

 1const user = {
 2    name: 'John',
 3    address: {
 4        city: 'New York'
 5    }
 6};
 7
 8// Set a default value for a non-existent property
 9const state = user?.address?.state || 'Unknown';
10console.log(state);  // Unknown
11
12// Example using the nullish coalescing operator
13const zipCode = user?.address?.zipCode ?? '00000';
14console.log(zipCode);  // 00000

লজিক্যাল OR অপারেটর false, 0, এবং '' এর মতো মানগুলিকে ফালসি হিসেবে গণ্য করে, কিন্তু নালিশ কোঅ্যালেসিং অপারেটর শুধুমাত্র যখন মানটি null অথবা undefined হয় তখনই ডিফল্ট মান ব্যবহার করে।

ঐচ্ছিক চেনিং এর সুবিধাসমূহ

  • নেস্টেড অবজেক্টে নিরাপদ প্রবেশাধিকার: ঐচ্ছিক চেনিং ব্যবহার করে, আপনাকে আর স্পষ্ট অস্তিত্ব পরীক্ষা করতে হবে না, যা কোডকে আরো সংক্ষিপ্ত করে।
  • ত্রুটি পরিহার: এটি রানটাইম ত্রুটি প্রতিরোধ করতে পারে, এমনকি যদি কোনও সম্পত্তি null বা undefined হয়।
  • উন্নত পাঠযোগ্যতা এবং রক্ষণাবেক্ষণ যোগ্যতা: বিশেষ করে যখন অনেক নেস্টেড অবজেক্ট নিয়ে কাজ করা হয়, কোডের পাঠযোগ্যতা উল্লেখযোগ্যভাবে বৃদ্ধি পায়।

ঐচ্ছিক চেনিং ব্যবহারে সতর্কতা

  • ঐচ্ছিক চেনিং এর ঘন ঘন ব্যবহার নির্দেশ করতে পারে যে ডেটা স্ট্রাকচারের ডিজাইন অতিরিক্ত জটিল। আপনার একটি সহজতর ডেটা মডেলের জন্য প্রচেষ্টা করা উচিত।
  • কারণ কিছু পুরনো ব্রাউজার এবং জাভাস্ক্রিপ্ট ইঞ্জিন এটি সমর্থন করে না, তাই আপনাকে পলিফিল বা ট্রান্সপাইলার ব্যবহার করতে হতে পারে।

উপসংহার

ঐচ্ছিক চেনিং একটি শক্তিশালী বৈশিষ্ট্য যা জাভাস্ক্রিপ্টে নেস্টেড অবজেক্টের সম্পত্তি এবং ফাংশনে নিরাপদ প্রবেশধিকার সহজতর করে। গভীরভাবে নেস্টেড ডেটা স্ট্রাকচার অ্যাক্সেস করার সময় এটি বিশেষভাবে কার্যকর, যা ত্রুটি প্রতিরোধ এবং কোডের উন্নত পাঠযোগ্যতায় সহায়তা করে।

আপনি আমাদের ইউটিউব চ্যানেলে ভিজ্যুয়াল স্টুডিও কোড ব্যবহার করে উপরের নিবন্ধটি অনুসরণ করতে পারেন। দয়া করে ইউটিউব চ্যানেলটিও দেখুন।

YouTube Video