Object-­‐‑Oriented  
Programming

  in

  JavaScript
Zander Magtipon
May 25, 2015
OOP  in  JavaScript
• Overview
• Prototype Chain
• Custom Objects
o The class
o The constructor
o The object (class instance)
o The property
o The method
o Static members
o Private and privileged members
• Inheritance
• Encapsulation
• Accessing Superclass Members
• Passing Constructor Arguments
Overview
• JavaScript is designed on a simple object-based
paradigm. An object is a collection of properties,
and a property is an association between a name
and a value. A property's value can be a function,
in which case the property is known as a method.
• One of the key differences of JavaScript from other
OOP languages is that it does not have classes.
Instead, JavaScript uses functions as classes.
• The class functionality is accomplished by object
prototypes where object inherits from another
object.
Overview
• JavaScript functions are objects, giving functions the
capacity to hold executable code and be passed
around like any other object.
• All objects in JavaScript are descended from Object
object.
• All objects inherit methods and properties from
Object.prototype.
• All object properties/methods are public.
Prototype  Chain
• A prototype chain is a finite chain of objects which is used
to implement inheritance and shared properties.
• Every object in JavaScript has an internal link to another
object called prototype. That prototype object has a
prototype of its own, and so on until an object is reached
with null as its prototype.
• __proto__ is the actual object that is used in the lookup
chain to resolve methods, etc.
• prototype is the object that is used to build __proto__ when
you create an object.
Prototype  Chain
var b = new Foo(20);
var c = new Foo(30);
Custom  Objects
• Defining a class is as easy as defining a function.
function Person() {
}
The class
Custom  Objects
• In JavaScript the function serves as the constructor
of the object.
• The constructor is used to set the object's properties
or to call methods to prepare the object for use.
function Person () {
console.log('instance created');
}
The constructor
Custom  Objects
• An instance of an object can be created by
executing the constructor function using the new
operator.
var person1 = new Person();
var person2 = new Person();
The object (class instance)
Custom  Objects
• Properties are set in the constructor of the class so
that they are created on each instance.
• The keyword this, which refers to the current object,
lets you work with properties from within the class.
The property (object attribute)
Custom  Objects
function Person(firstName) {
this.firstName = firstName;
console.log('Person instantiated');
}
var person1 = new Person('Alice');
var person2 = new Person('Bob');
// Show the firstName properties of the objects
console.log('person1 is ' + person1.firstName); // logs "person1 is Alice"
console.log('person2 is ' + person2.firstName); // logs "person2 is Bob"
The property (object attribute)
Custom  Objects
• Methods are functions that follow the same logic as
properties. Calling a method is similar to accessing a
property, but you add () at the end of the method
name, possibly with arguments.
• To define a method, assign a function to a named
property of the class's prototype property.
The method
Custom  Objects
function Person(firstName) {
this.firstName = firstName;
}
Person.prototype.sayHello = function() {
console.log("Hello, I'm " + this.firstName);
};
var person1 = new Person("Alice");
var person2 = new Person("Bob");
// call the Person sayHello method.
person1.sayHello(); // logs "Hello, I'm Alice"
person2.sayHello(); // logs "Hello, I'm Bob"
The method
Custom  Objects
• Static members (properties/methods) or class
members only exist on the class and doesn't exist on
child objects.
Static members
Custom  Objects
function Person(firstName) {
this.firstName = firstName;
}
Person.prototype.sayName = function() {
console.log("instance:", this.firstName);
};
Person.firstName = "anybody";
Person.sayName = function() {
console.log("static:", this.firstName);
};
var person1 = new Person("Alice");
person1.sayName(); // logs "instance: Alice"
Person.sayName(); // logs "static: anybody"
Static members
Custom  Objects
• Private members are made by the constructor. Local
vars and parameters of the constructor becomes
the private members.
• A privileged method is able to access the private
variables and methods, and is itself accessible to the
public methods and the outside.
Private and privileged members
Custom  Objects
function Person(firstName) {
//-- private
var _firstName = firstName;
function _getMessage() {
return "Hello my name is " + _firstName;
}
//-- privileged
this.sayHello = function() {
console.log(_getMessage());
}
}
var person1 = new Person("Alice");
person1. sayHello(); // logs "Hello my name is Alice"
Private and privileged members
Inheritance
• Inheritance is a way to create a class as a specialized
version of another class.
• JavaScript only supports single inheritance.
• When trying to access a property of an object, the
property will not only be sought on the object but on the
prototype of the object, the prototype of the prototype,
and so on until either a property with a matching name is
found or the end of the prototype chain is reached.
• When an inherited function is executed, the value of this
points to the inheriting object, not to the prototype
object where the function is an own property.
Inheritance
function Photo(name) {
this.name = name || "photo";
}
Photo.prototype.upload = function() {
console.log("Photo.upload:", this.name);
};
ProfilePhoto.prototype = Object.create(Photo.prototype);
function ProfilePhoto(name) {
Photo.call(this, name || "profile-photo");
}
var photo = new Photo();
photo.upload(); // logs "Photo.upload: photo"
var profilePhoto = new ProfilePhoto();
profilePhoto.upload(); // logs "Photo.upload: profile-photo"
Inheritance
function Photo(name) {
this.name = name || "photo";
}
Photo.prototype.upload = function() {
console.log("Photo.upload:", this.name);
};
ProfilePhoto.prototype = Object.create(Photo.prototype);
function ProfilePhoto(name) {
Photo.call(this, name || "profile-photo");
}
//-- method override
ProfilePhoto.prototype.upload = function() {
console.log("ProfilePhoto.upload:", this.name);
};
var photo = new Photo();
photo.upload(); // logs "Photo.upload: photo"
var profilePhoto = new ProfilePhoto();
profilePhoto.upload(); // logs "ProfilePhoto.upload: profile-photo"
Encapsulation
• Encapsulation includes the idea that the data of an
object should not be directly exposed.
• Instead, callers that want to achieve a given result
are coaxed into proper usage by invoking methods
(rather than accessing the data directly).
Encapsulation
function Photo(name) {
this.name = name || "photo";
}
Photo.prototype.setName = function(name) {
this.name = name;
};
Photo.prototype.getName = function() {
return this.name;
};
var photo = new Photo();
photo.setName("picture"); // sets photo name to "picture"
photo.getName(); // returns "picture"
Encapsulation
function Photo(name) {
var _name = name || "photo";
Object.defineProperty(this, "name", {
get: function() {
return _name;
},
set: function(name) {
_name = name;
}
});
}
var photo = new Photo();
photo.name = "picture"; // sets photo name to "picture"
photo.name; // returns “picture”
Accessing  Superclass  
Members
• One of the big differences between Classical
(Object-Oriented) and Prototypal inheritance is that
the former has an elegant mechanism for referring
to the parent class (usually using the super keyword).
It's often used in constructors to initialize the parent
class with the supplied input parameters. Another
common usage is to extend parent functionality in
the child class.
Accessing  Superclass  
Members
function Photo(name) {
var _name = name || "photo";
Object.defineProperty(this, "name", {
get: function() {
return _name;
}
});
}
Photo.prototype.upload = function() {
console.log("Photo.upload:", this.name);
};
Accessing  Superclass  
Members
ProfilePhoto.prototype = Object.create(Photo.prototype);
function ProfilePhoto(name) {
Photo.call(this, name || "profile-photo");
}
//-- method override
ProfilePhoto.prototype.upload = function() {
Photo.prototype.upload.call(this);
console.log(”ProfilePhoto.upload:", this.name);
};
var profilePhoto = new ProfilePhoto();
profilePhoto.upload();
// logs "Photo.upload: profile-photo"
// logs "ProfilePhoto.upload: profile-photo"
Accessing  Superclass  
Members
ProfilePhoto.prototype = Object.create(Photo.prototype);
function ProfilePhoto(name) {
Object.defineProperty(this, "parent", {
get: function() {
return Photo;
}
});
this.parent.call(this, name || "profile-photo");
}
//-- method override
ProfilePhoto.prototype.upload = function() {
this.parent.prototype.upload.call(this);
console.log(”ProfilePhoto.upload:", this.name);
};
var profilePhoto = new ProfilePhoto();
profilePhoto.upload();
// logs "Photo.upload: profile-photo"
// logs "ProfilePhoto.upload: profile-photo"
Passing  Constructor  
Arguments
function Photo(name) {
var _name = name || "photo";
Object.defineProperty(this, "name", {
get: function() {
return _name;
}
});
}
ProfilePhoto.prototype = Object.create(Photo.prototype);
function ProfilePhoto() {
Photo.apply(this, Array.prototype.slice.call(arguments));
}
var profilePhoto = new ProfilePhoto("avatar"); // sets the name to "avatar"
Questions?
Thank  You!

More Related Content

PPTX
Object Oriented Programming In JavaScript
PDF
JavaScript Programming
PPT
Advanced JavaScript
PPT
Advanced JavaScript
PPTX
Advanced JavaScript
PDF
JavaScript guide 2020 Learn JavaScript
PPTX
React workshop
PDF
jQuery -Chapter 2 - Selectors and Events
Object Oriented Programming In JavaScript
JavaScript Programming
Advanced JavaScript
Advanced JavaScript
Advanced JavaScript
JavaScript guide 2020 Learn JavaScript
React workshop
jQuery -Chapter 2 - Selectors and Events

What's hot (20)

PDF
REST API and CRUD
PDF
Advanced javascript
PPTX
[Final] ReactJS presentation
PPTX
Javascript functions
PDF
Introduction to Java 11
PPTX
Introduction to Web Development - JavaScript
PDF
Angular
PPT
JavaScript Basics
PDF
Introduction into ES6 JavaScript.
PPTX
What is component in reactjs
PPTX
An Introduction To REST API
PDF
Workshop 21: React Router
PDF
Basics of JavaScript
PPTX
Introduction to React JS for beginners
PPTX
Object Oriented Programming with C#
PDF
JavaScript Fetch API
PPTX
Javascript 101
PPT
JavaScript & Dom Manipulation
ODP
Introduction to ReactJS
PPTX
JavaScript Basics
REST API and CRUD
Advanced javascript
[Final] ReactJS presentation
Javascript functions
Introduction to Java 11
Introduction to Web Development - JavaScript
Angular
JavaScript Basics
Introduction into ES6 JavaScript.
What is component in reactjs
An Introduction To REST API
Workshop 21: React Router
Basics of JavaScript
Introduction to React JS for beginners
Object Oriented Programming with C#
JavaScript Fetch API
Javascript 101
JavaScript & Dom Manipulation
Introduction to ReactJS
JavaScript Basics
Ad

Viewers also liked (20)

ODP
JavaScript Object Oriented Programming Cheat Sheet
PDF
Javascript cheat-sheet-v1
PDF
Prototype
PPTX
Javascript Prototype Visualized
PDF
Prototype-based Programming with JavaScript
ODP
JavaScript global object, execution contexts & closures
PPTX
Grunt
PDF
JavaScript Prototype and Module Pattern
PDF
Introduction to Object Oriented Javascript
PPT
Object Oriented JavaScript
PPTX
Workshop 1: Good practices in JavaScript
PDF
CSS Sanity with Sass: The Inverted Triangle Approach
PPTX
JavaScript in Object-Oriented Way
PPTX
SASS - CSS with Superpower
KEY
Advanced sass/compass
PPTX
View, Act, and React: Shaping Business Activity with Analytics, BigData Queri...
PDF
Smart CSS theming with Sass and Compass
PPTX
Syntactically awesome stylesheets (Sass)
PDF
JavaScript OOPs
PPTX
Ipsec 2
JavaScript Object Oriented Programming Cheat Sheet
Javascript cheat-sheet-v1
Prototype
Javascript Prototype Visualized
Prototype-based Programming with JavaScript
JavaScript global object, execution contexts & closures
Grunt
JavaScript Prototype and Module Pattern
Introduction to Object Oriented Javascript
Object Oriented JavaScript
Workshop 1: Good practices in JavaScript
CSS Sanity with Sass: The Inverted Triangle Approach
JavaScript in Object-Oriented Way
SASS - CSS with Superpower
Advanced sass/compass
View, Act, and React: Shaping Business Activity with Analytics, BigData Queri...
Smart CSS theming with Sass and Compass
Syntactically awesome stylesheets (Sass)
JavaScript OOPs
Ipsec 2
Ad

Similar to Object Oriented Programming in JavaScript (20)

PPTX
JavsScript OOP
PPTX
Object Oriented Javascript part2
PPTX
JavaScript OOPS Implimentation
PPTX
Object oriented javascript
PPT
Javascript Object Oriented Programming
KEY
Javascript tid-bits
PPTX
pert.3&4.pptx
PPT
Beginning Object-Oriented JavaScript
PPT
Advanced Javascript
PPT
Advanced Javascript
PPT
Advanced Javascript
PPTX
Understanding-Objects-in-Javascript.pptx
PPTX
Framework prototype
PPTX
Framework prototype
PPTX
Framework prototype
PPTX
Ajaxworld
PPTX
Object oriented javascript
PPT
JavaScript In Object Oriented Way
PDF
JS Level Up: Prototypes
PPTX
Object oriented programming in JavaScript
JavsScript OOP
Object Oriented Javascript part2
JavaScript OOPS Implimentation
Object oriented javascript
Javascript Object Oriented Programming
Javascript tid-bits
pert.3&4.pptx
Beginning Object-Oriented JavaScript
Advanced Javascript
Advanced Javascript
Advanced Javascript
Understanding-Objects-in-Javascript.pptx
Framework prototype
Framework prototype
Framework prototype
Ajaxworld
Object oriented javascript
JavaScript In Object Oriented Way
JS Level Up: Prototypes
Object oriented programming in JavaScript

Recently uploaded (20)

PPTX
Download Adobe Photoshop Crack 2025 Free
PDF
How Tridens DevSecOps Ensures Compliance, Security, and Agility
PDF
Multiverse AI Review 2025: Access All TOP AI Model-Versions!
PPTX
Lecture 5 Software Requirement Engineering
PDF
Internet Download Manager IDM Crack powerful download accelerator New Version...
PDF
AI/ML Infra Meetup | LLM Agents and Implementation Challenges
DOC
UTEP毕业证学历认证,宾夕法尼亚克拉里恩大学毕业证未毕业
PDF
Topaz Photo AI Crack New Download (Latest 2025)
PDF
AI-Powered Threat Modeling: The Future of Cybersecurity by Arun Kumar Elengov...
PDF
Introduction to Ragic - #1 No Code Tool For Digitalizing Your Business Proces...
PPTX
Tech Workshop Escape Room Tech Workshop
PDF
E-Commerce Website Development Companyin india
PDF
PDF-XChange Editor Plus 10.7.0.398.0 Crack Free Download Latest 2025
DOCX
Modern SharePoint Intranet Templates That Boost Employee Engagement in 2025.docx
PPTX
Full-Stack Developer Courses That Actually Land You Jobs
PDF
DNT Brochure 2025 – ISV Solutions @ D365
PPTX
4Seller: The All-in-One Multi-Channel E-Commerce Management Platform for Glob...
PDF
Guide to Food Delivery App Development.pdf
DOCX
How to Use SharePoint as an ISO-Compliant Document Management System
PDF
AI Guide for Business Growth - Arna Softech
Download Adobe Photoshop Crack 2025 Free
How Tridens DevSecOps Ensures Compliance, Security, and Agility
Multiverse AI Review 2025: Access All TOP AI Model-Versions!
Lecture 5 Software Requirement Engineering
Internet Download Manager IDM Crack powerful download accelerator New Version...
AI/ML Infra Meetup | LLM Agents and Implementation Challenges
UTEP毕业证学历认证,宾夕法尼亚克拉里恩大学毕业证未毕业
Topaz Photo AI Crack New Download (Latest 2025)
AI-Powered Threat Modeling: The Future of Cybersecurity by Arun Kumar Elengov...
Introduction to Ragic - #1 No Code Tool For Digitalizing Your Business Proces...
Tech Workshop Escape Room Tech Workshop
E-Commerce Website Development Companyin india
PDF-XChange Editor Plus 10.7.0.398.0 Crack Free Download Latest 2025
Modern SharePoint Intranet Templates That Boost Employee Engagement in 2025.docx
Full-Stack Developer Courses That Actually Land You Jobs
DNT Brochure 2025 – ISV Solutions @ D365
4Seller: The All-in-One Multi-Channel E-Commerce Management Platform for Glob...
Guide to Food Delivery App Development.pdf
How to Use SharePoint as an ISO-Compliant Document Management System
AI Guide for Business Growth - Arna Softech

Object Oriented Programming in JavaScript

  • 1. Object-­‐‑Oriented   Programming
  in
  JavaScript Zander Magtipon May 25, 2015
  • 2. OOP  in  JavaScript • Overview • Prototype Chain • Custom Objects o The class o The constructor o The object (class instance) o The property o The method o Static members o Private and privileged members • Inheritance • Encapsulation • Accessing Superclass Members • Passing Constructor Arguments
  • 3. Overview • JavaScript is designed on a simple object-based paradigm. An object is a collection of properties, and a property is an association between a name and a value. A property's value can be a function, in which case the property is known as a method. • One of the key differences of JavaScript from other OOP languages is that it does not have classes. Instead, JavaScript uses functions as classes. • The class functionality is accomplished by object prototypes where object inherits from another object.
  • 4. Overview • JavaScript functions are objects, giving functions the capacity to hold executable code and be passed around like any other object. • All objects in JavaScript are descended from Object object. • All objects inherit methods and properties from Object.prototype. • All object properties/methods are public.
  • 5. Prototype  Chain • A prototype chain is a finite chain of objects which is used to implement inheritance and shared properties. • Every object in JavaScript has an internal link to another object called prototype. That prototype object has a prototype of its own, and so on until an object is reached with null as its prototype. • __proto__ is the actual object that is used in the lookup chain to resolve methods, etc. • prototype is the object that is used to build __proto__ when you create an object.
  • 6. Prototype  Chain var b = new Foo(20); var c = new Foo(30);
  • 7. Custom  Objects • Defining a class is as easy as defining a function. function Person() { } The class
  • 8. Custom  Objects • In JavaScript the function serves as the constructor of the object. • The constructor is used to set the object's properties or to call methods to prepare the object for use. function Person () { console.log('instance created'); } The constructor
  • 9. Custom  Objects • An instance of an object can be created by executing the constructor function using the new operator. var person1 = new Person(); var person2 = new Person(); The object (class instance)
  • 10. Custom  Objects • Properties are set in the constructor of the class so that they are created on each instance. • The keyword this, which refers to the current object, lets you work with properties from within the class. The property (object attribute)
  • 11. Custom  Objects function Person(firstName) { this.firstName = firstName; console.log('Person instantiated'); } var person1 = new Person('Alice'); var person2 = new Person('Bob'); // Show the firstName properties of the objects console.log('person1 is ' + person1.firstName); // logs "person1 is Alice" console.log('person2 is ' + person2.firstName); // logs "person2 is Bob" The property (object attribute)
  • 12. Custom  Objects • Methods are functions that follow the same logic as properties. Calling a method is similar to accessing a property, but you add () at the end of the method name, possibly with arguments. • To define a method, assign a function to a named property of the class's prototype property. The method
  • 13. Custom  Objects function Person(firstName) { this.firstName = firstName; } Person.prototype.sayHello = function() { console.log("Hello, I'm " + this.firstName); }; var person1 = new Person("Alice"); var person2 = new Person("Bob"); // call the Person sayHello method. person1.sayHello(); // logs "Hello, I'm Alice" person2.sayHello(); // logs "Hello, I'm Bob" The method
  • 14. Custom  Objects • Static members (properties/methods) or class members only exist on the class and doesn't exist on child objects. Static members
  • 15. Custom  Objects function Person(firstName) { this.firstName = firstName; } Person.prototype.sayName = function() { console.log("instance:", this.firstName); }; Person.firstName = "anybody"; Person.sayName = function() { console.log("static:", this.firstName); }; var person1 = new Person("Alice"); person1.sayName(); // logs "instance: Alice" Person.sayName(); // logs "static: anybody" Static members
  • 16. Custom  Objects • Private members are made by the constructor. Local vars and parameters of the constructor becomes the private members. • A privileged method is able to access the private variables and methods, and is itself accessible to the public methods and the outside. Private and privileged members
  • 17. Custom  Objects function Person(firstName) { //-- private var _firstName = firstName; function _getMessage() { return "Hello my name is " + _firstName; } //-- privileged this.sayHello = function() { console.log(_getMessage()); } } var person1 = new Person("Alice"); person1. sayHello(); // logs "Hello my name is Alice" Private and privileged members
  • 18. Inheritance • Inheritance is a way to create a class as a specialized version of another class. • JavaScript only supports single inheritance. • When trying to access a property of an object, the property will not only be sought on the object but on the prototype of the object, the prototype of the prototype, and so on until either a property with a matching name is found or the end of the prototype chain is reached. • When an inherited function is executed, the value of this points to the inheriting object, not to the prototype object where the function is an own property.
  • 19. Inheritance function Photo(name) { this.name = name || "photo"; } Photo.prototype.upload = function() { console.log("Photo.upload:", this.name); }; ProfilePhoto.prototype = Object.create(Photo.prototype); function ProfilePhoto(name) { Photo.call(this, name || "profile-photo"); } var photo = new Photo(); photo.upload(); // logs "Photo.upload: photo" var profilePhoto = new ProfilePhoto(); profilePhoto.upload(); // logs "Photo.upload: profile-photo"
  • 20. Inheritance function Photo(name) { this.name = name || "photo"; } Photo.prototype.upload = function() { console.log("Photo.upload:", this.name); }; ProfilePhoto.prototype = Object.create(Photo.prototype); function ProfilePhoto(name) { Photo.call(this, name || "profile-photo"); } //-- method override ProfilePhoto.prototype.upload = function() { console.log("ProfilePhoto.upload:", this.name); }; var photo = new Photo(); photo.upload(); // logs "Photo.upload: photo" var profilePhoto = new ProfilePhoto(); profilePhoto.upload(); // logs "ProfilePhoto.upload: profile-photo"
  • 21. Encapsulation • Encapsulation includes the idea that the data of an object should not be directly exposed. • Instead, callers that want to achieve a given result are coaxed into proper usage by invoking methods (rather than accessing the data directly).
  • 22. Encapsulation function Photo(name) { this.name = name || "photo"; } Photo.prototype.setName = function(name) { this.name = name; }; Photo.prototype.getName = function() { return this.name; }; var photo = new Photo(); photo.setName("picture"); // sets photo name to "picture" photo.getName(); // returns "picture"
  • 23. Encapsulation function Photo(name) { var _name = name || "photo"; Object.defineProperty(this, "name", { get: function() { return _name; }, set: function(name) { _name = name; } }); } var photo = new Photo(); photo.name = "picture"; // sets photo name to "picture" photo.name; // returns “picture”
  • 24. Accessing  Superclass   Members • One of the big differences between Classical (Object-Oriented) and Prototypal inheritance is that the former has an elegant mechanism for referring to the parent class (usually using the super keyword). It's often used in constructors to initialize the parent class with the supplied input parameters. Another common usage is to extend parent functionality in the child class.
  • 25. Accessing  Superclass   Members function Photo(name) { var _name = name || "photo"; Object.defineProperty(this, "name", { get: function() { return _name; } }); } Photo.prototype.upload = function() { console.log("Photo.upload:", this.name); };
  • 26. Accessing  Superclass   Members ProfilePhoto.prototype = Object.create(Photo.prototype); function ProfilePhoto(name) { Photo.call(this, name || "profile-photo"); } //-- method override ProfilePhoto.prototype.upload = function() { Photo.prototype.upload.call(this); console.log(”ProfilePhoto.upload:", this.name); }; var profilePhoto = new ProfilePhoto(); profilePhoto.upload(); // logs "Photo.upload: profile-photo" // logs "ProfilePhoto.upload: profile-photo"
  • 27. Accessing  Superclass   Members ProfilePhoto.prototype = Object.create(Photo.prototype); function ProfilePhoto(name) { Object.defineProperty(this, "parent", { get: function() { return Photo; } }); this.parent.call(this, name || "profile-photo"); } //-- method override ProfilePhoto.prototype.upload = function() { this.parent.prototype.upload.call(this); console.log(”ProfilePhoto.upload:", this.name); }; var profilePhoto = new ProfilePhoto(); profilePhoto.upload(); // logs "Photo.upload: profile-photo" // logs "ProfilePhoto.upload: profile-photo"
  • 28. Passing  Constructor   Arguments function Photo(name) { var _name = name || "photo"; Object.defineProperty(this, "name", { get: function() { return _name; } }); } ProfilePhoto.prototype = Object.create(Photo.prototype); function ProfilePhoto() { Photo.apply(this, Array.prototype.slice.call(arguments)); } var profilePhoto = new ProfilePhoto("avatar"); // sets the name to "avatar"