Class Methods এবং Properties তৈরি

Prototype এর Object Oriented Programming (OOP) - প্রোটোটাইপ ফ্রেমওয়ার্ক (Prototype Framework) - Web Development

212

Prototype Framework একটি JavaScript library যা ওয়েব ডেভেলপমেন্টে ব্যবহারকারীদের জন্য সহজ এবং কার্যকরী টুলস প্রদান করে। এটি অনেক কার্যকারিতা সরবরাহ করে, যার মধ্যে রয়েছে AJAX, DOM manipulation, Event handling, এবং Class-based programmingPrototype Framework-এ Class Methods এবং Properties তৈরি করা একটি গুরুত্বপূর্ণ বৈশিষ্ট্য, যা JavaScript ক্লাস ভিত্তিক পদ্ধতির মাধ্যমে কোড সংগঠিত এবং পুনঃব্যবহারযোগ্য করে তোলে।

Class Methods এবং Properties তৈরি করা:

Prototype Framework-এ Class Methods এবং Properties তৈরি করার জন্য Class.create ফাংশন ব্যবহার করা হয়। এর মাধ্যমে আপনি নতুন ক্লাস তৈরি করতে পারেন এবং সেই ক্লাসের মধ্যে methods (ফাংশন) এবং properties (অবজেক্টের প্রপার্টি) যুক্ত করতে পারেন।

1. Class Creation in Prototype Framework:

Prototype Framework এ ক্লাস তৈরি করতে Class.create মেথড ব্যবহার করা হয়, যা একটি নতুন ক্লাস তৈরি করে। এই ক্লাসের মধ্যে আপনি properties এবং methods সংজ্ঞায়িত করতে পারেন।

Syntax:

var MyClass = Class.create({
    // Class properties
    property1: 'value1',
    property2: 'value2',

    // Class methods
    method1: function() {
        console.log('Method 1');
    },
    
    method2: function() {
        console.log('Method 2');
    }
});

এখানে, MyClass একটি নতুন ক্লাস তৈরি করা হয়েছে এবং তার মধ্যে দুটি properties (property1, property2) এবং দুটি methods (method1, method2) ডিফাইন করা হয়েছে।


2. Creating Class Methods and Properties:

আপনি যখন একটি ক্লাস তৈরি করেন, তখন আপনি সেই ক্লাসের মধ্যে methods (ফাংশন) এবং properties (অবজেক্টের ভ্যালু) সংজ্ঞায়িত করতে পারেন।

Example: Class with Methods and Properties:

var Person = Class.create({
    // Class properties
    name: 'John Doe',
    age: 30,

    // Class methods
    initialize: function(name, age) {
        this.name = name;
        this.age = age;
    },

    greet: function() {
        console.log('Hello, my name is ' + this.name);
    },

    birthday: function() {
        this.age += 1;
        console.log('Happy Birthday! You are now ' + this.age + ' years old.');
    }
});

// Creating a new instance of the class
var person1 = new Person('Alice', 25);

// Accessing properties and methods
console.log(person1.name); // 'Alice'
person1.greet(); // 'Hello, my name is Alice'
person1.birthday(); // 'Happy Birthday! You are now 26 years old.'

Explanation:

  1. Properties: name এবং age হল class properties, যা ক্লাসের ইনস্ট্যান্সের জন্য ডিফাইন করা হয়েছে।
  2. Methods: greet এবং birthday হল methods, যা ক্লাসের ইনস্ট্যান্সের ফাংশনালিটি প্রদান করে।
  3. initialize() method: এটি ক্লাসের কনস্ট্রাক্টর, যা নতুন ইনস্ট্যান্স তৈরি করার সময় প্যারামিটার হিসেবে name এবং age সেট করে।

3. Accessing Class Methods and Properties:

যখন আপনি একটি নতুন ক্লাস তৈরি করবেন এবং তার একটি ইনস্ট্যান্স তৈরি করবেন, তখন আপনি সেই ইনস্ট্যান্সের মাধ্যমে methods এবং properties অ্যাক্সেস করতে পারবেন।

Example: Accessing Methods and Properties:

var Car = Class.create({
    make: 'Toyota',
    model: 'Corolla',
    year: 2020,

    initialize: function(make, model, year) {
        this.make = make;
        this.model = model;
        this.year = year;
    },

    start: function() {
        console.log('The ' + this.make + ' ' + this.model + ' is starting.');
    },

    stop: function() {
        console.log('The ' + this.make + ' ' + this.model + ' has stopped.');
    }
});

// Creating an instance of the Car class
var myCar = new Car('Honda', 'Civic', 2021);

// Accessing properties
console.log(myCar.make);  // 'Honda'
console.log(myCar.year);  // 2021

// Calling methods
myCar.start();  // 'The Honda Civic is starting.'
myCar.stop();   // 'The Honda Civic has stopped.'

Explanation:

  • Properties: make, model, এবং year হল properties যা গাড়ির ব্র্যান্ড, মডেল, এবং উৎপাদন বছর সংরক্ষণ করে।
  • Methods: start() এবং stop() হল methods, যা গাড়ি স্টার্ট এবং স্টপ করার কাজ সম্পাদন করে।

4. Static Methods and Properties:

Prototype Framework এ static methods এবং static properties সংজ্ঞায়িত করা সম্ভব, যা ক্লাসের instance এর উপর নয়, বরং ক্লাসের উপর প্রয়োগ হয়।

Example: Static Methods and Properties:

var Animal = Class.create({
    // Static property
    species: 'Unknown',

    // Static method
    initialize: function(name) {
        this.name = name;
    },

    greet: function() {
        console.log('Hello, I am a ' + this.species + ' and my name is ' + this.name);
    },

    // Static method
    staticMethod: function() {
        console.log('This is a static method.');
    }
});

// Accessing the static method directly from the class
Animal.staticMethod();  // 'This is a static method.'

Explanation:

  • Static Methods: staticMethod() হল একটি static method, যা ক্লাসের ইনস্ট্যান্স তৈরি না করেই সরাসরি ক্লাস থেকে অ্যাক্সেস করা যায়।
  • Static Property: species একটি static property, যেটি ক্লাসের instance এর মাধ্যমে অ্যাক্সেস করা না যায়, তবে ক্লাসের মাধ্যমে অ্যাক্সেস করা সম্ভব।

5. Inheritance in Prototype Framework:

Prototype Framework এ inheritance ব্যবস্থাপনা করা যায়, যাতে আপনি একটি ক্লাস থেকে অন্য ক্লাসের বৈশিষ্ট্য এবং ফাংশনালিটি উত্তরাধিকার (inherit) করতে পারেন।

Example: Inheritance:

var Animal = Class.create({
    initialize: function(name) {
        this.name = name;
    },

    speak: function() {
        console.log(this.name + ' makes a sound.');
    }
});

var Dog = Class.create(Animal, {
    initialize: function($super, name, breed) {
        $super(name);
        this.breed = breed;
    },

    speak: function() {
        console.log(this.name + ' barks.');
    }
});

// Creating an instance of Dog
var myDog = new Dog('Buddy', 'Golden Retriever');

// Calling inherited method
myDog.speak();  // 'Buddy barks.'

Explanation:

  • $super(): এটি superclass (অর্থাৎ পূর্ববর্তী ক্লাস) এর মেথড বা কনস্ট্রাক্টর কল করতে ব্যবহৃত হয়।
  • Inheritance: Dog ক্লাসটি Animal ক্লাস থেকে উত্তরাধিকার পেয়েছে এবং সেখানে কিছু কাস্টম মেথড (যেমন speak) কাস্টমাইজ করা হয়েছে।

Prototype Framework-এ Class Methods এবং Properties তৈরি করার মাধ্যমে আপনি JavaScript ক্লাস ভিত্তিক প্রোগ্রামিং ব্যবহার করে কোড সংগঠিত এবং পুনঃব্যবহারযোগ্য করতে পারেন। এর মাধ্যমে আপনি ক্লাসের ইনস্ট্যান্স তৈরি করতে পারেন, সেই ইনস্ট্যান্সের properties এবং methods অ্যাক্সেস করতে পারেন, এবং inheritance ব্যবস্থার মাধ্যমে কোডকে আরও মডুলার এবং স্কেলেবল করতে পারেন। Prototype Framework এই কাজগুলোকে আরও সহজ এবং কার্যকরী করে তোলে।

Content added By
Promotion

Are you sure to start over?

Loading...