This tutorial aims to guide you through the best practices for Object-Oriented Programming (OOP) in JavaScript. By the end of this tutorial, you will be able to write efficient, maintainable code using JavaScript's OOP principles.
What you will learn:
- The fundamental concepts of JavaScript OOP
- How to implement these concepts in JavaScript
- Best practices for writing clean, maintainable code
Prerequisites:
Basic understanding of JavaScript syntax and concepts (variables, functions, etc.)
JavaScript OOP is built around four main principles: Encapsulation, Inheritance, Abstraction, and Polymorphism.
Encapsulation: This is the practice of keeping fields within a class private. This helps to prevent unauthorized access and modification of data.
Inheritance: This is a way for one class to extend another class, thereby inheriting its properties and methods.
Abstraction: This concept involves hiding complex details and showing only the essentials.
Polymorphism: This allows objects to be represented in multiple forms.
function Car(make, model, year) {
  this.make = make;
  this.model = model;
  var yearPrivate = year; // private property
  // Accessor for the private property
  this.getYear = function() {
    return yearPrivate;
  }
}
var myCar = new Car('Toyota', 'Corolla', 2005);
console.log(myCar.getYear()); // Outputs: 2005
In the above example, yearPrivate is a private property that can only be accessed through the getYear method.
function Vehicle(make, model) {
  this.make = make;
  this.model = model;
}
Vehicle.prototype.startEngine = function() {
  return 'Engine started';
}
function Car(make, model, doors) {
  Vehicle.call(this, make, model);
  this.doors = doors;
}
Car.prototype = Object.create(Vehicle.prototype);
Car.prototype.constructor = Car;
var myCar = new Car('Toyota', 'Corolla', 4);
console.log(myCar.startEngine()); // Outputs: "Engine started"
In this example, Car inherits from Vehicle.
In this tutorial, we covered the four pillars of JavaScript OOP: Encapsulation, Inheritance, Abstraction, and Polymorphism. We also went through the best practices for writing maintainable code.
Exercise 1: Create a Person object with properties name and age and a method greet that outputs a greeting message.
Solution:
function Person(name, age) {
  this.name = name;
  this.age = age;
  this.greet = function() {
    return "Hello, my name is " + this.name + " and I'm " + this.age + " years old.";
  }
}
var john = new Person('John', 25);
console.log(john.greet()); // Outputs: "Hello, my name is John and I'm 25 years old."
Exercise 2: Create a Student object that inherits from Person and has an additional property course.
Solution:
function Student(name, age, course) {
  Person.call(this, name, age);
  this.course = course;
}
Student.prototype = Object.create(Person.prototype);
Student.prototype.constructor = Student;
var jane = new Student('Jane', 22, 'Computer Science');
console.log(jane.greet()); // Outputs: "Hello, my name is Jane and I'm 22 years old."
Tips for Further Practice:
Try creating more complex objects and practice using encapsulation, inheritance, abstraction, and polymorphism.