KEMBAR78
Object Oriented Programming | class | object | PDF
OBJECT ORIENTED
PROGRAMMING (OOP)
WITH JAVASCRIPT
SECTION
LECTURE
OBJECT ORIENTED PROGRAMMING
(OOP) WITH JAVASCRIPT
WHAT IS OBJECT-ORIENTED
PROGRAMMING?
WHAT IS OBJECT-ORIENTED PROGRAMMING? (OOP)
OOP
Style of code, “how” we
write and organize code
👉 Object-oriented programming (OOP) is a programming paradigm based on the
concept of objects;
👉 We use objects to model (describe) real-world or abstract features;
👉 Objects may contain data (properties) and code (methods). By using objects, we
pack data and the corresponding behavior into one block;
👉 In OOP, objects are self-contained pieces/blocks of code;
👉 Objects are building blocks of applications, and interact with one another;
👉 Interactions happen through a public interface (API): methods that the code
outside of the object can access and use to communicate with the object;
👉 OOP was developed with the goal of organizing code, to make it more flexible
and easier to maintain (avoid “spaghetti code”).
E.g. user or todo list item
E.g. HTML component or data structure
Data
Behaviour
Like a blueprint from
which we can create
new objects
CLASSES AND INSTANCES (TRADITIONAL OOP)
CLASS
Instance
Instance
Instance
Just a representation,
NOT actual JavaScript
syntax!
JavaScript does NOT
support real classes
like represented here
New object created from the class. Like a
real house created from an abstract blueprint
☝ Conceptual overview: it works
a bit differently in JavaScript.
Still important to understand!
THE 4 FUNDAMENTAL OOP PRINCIPLES
Abstraction
Polymorphism
Inheritance
Encapsulation
The 4 fundamental
principles of Object-
Oriented Programming
🤔 “How do we actually design classes? How
do we model real-world data into classes?”
PRINCIPLE 1: ABSTRACTION
Polymorphism
Inheritance
Abstraction
Encapsulation
👉 Abstraction: Ignoring or hiding details that don’t matter, allowing us to
get an overview perspective of the thing we’re implementing, instead of
messing with details that don’t really matter to our implementation.
Real phone Abstracted phone
Do we really need all these low-level details?
Details have been
abstracted away
PRINCIPLE 2: ENCAPSULATION
Polymorphism
Inheritance
Again, NOT actually JavaScript
syntax (the private keyword
doesn’t exist)
Abstraction
Encapsulation
👉 Encapsulation: Keeping properties and methods private inside the class,
so they are not accessible from outside the class. Some methods can
be exposed as a public interface (API).
NOT accessible from
outside the class!
STILL accessible from
within the class!
NOT accessible from
outside the class!
STILL accessible from
within the class!
👉 Prevents external code from
accidentally manipulating
internal properties/state
👉 Allows to change internal
implementation without the
risk of breaking external code
WHY?
PRINCIPLE 3: INHERITANCE
Polymorphism
Inheritance
Abstraction
Encapsulation
👉 Inheritance: Making all properties and methods of a certain class available
to a child class, forming a hierarchical relationship between classes. This
allows us to reuse common logic and to model real-world relationships.
PARENT CLASS
CHILD CLASS
INHERITANCE
Inherited
OWN methods
and properties
Inherited
CHILD CLASS EXTENDS PARENT CLASS
PRINCIPLE 4: POLYMORPHISM
Inheritance
Polymorphism
Abstraction
Encapsulation
👉 Polymorphism: A child class can overwrite a method it inherited from a
parent class [it’s more complex that that, but enough for our purposes].
PARENT CLASS
CHILD CLASS CHILD CLASS
INHERITANCE INHERITANCE
Own login method,
overwriting login method
inherited from User

Object Oriented Programming | class | object

  • 1.
  • 2.
    SECTION LECTURE OBJECT ORIENTED PROGRAMMING (OOP)WITH JAVASCRIPT WHAT IS OBJECT-ORIENTED PROGRAMMING?
  • 3.
    WHAT IS OBJECT-ORIENTEDPROGRAMMING? (OOP) OOP Style of code, “how” we write and organize code 👉 Object-oriented programming (OOP) is a programming paradigm based on the concept of objects; 👉 We use objects to model (describe) real-world or abstract features; 👉 Objects may contain data (properties) and code (methods). By using objects, we pack data and the corresponding behavior into one block; 👉 In OOP, objects are self-contained pieces/blocks of code; 👉 Objects are building blocks of applications, and interact with one another; 👉 Interactions happen through a public interface (API): methods that the code outside of the object can access and use to communicate with the object; 👉 OOP was developed with the goal of organizing code, to make it more flexible and easier to maintain (avoid “spaghetti code”). E.g. user or todo list item E.g. HTML component or data structure Data Behaviour
  • 4.
    Like a blueprintfrom which we can create new objects CLASSES AND INSTANCES (TRADITIONAL OOP) CLASS Instance Instance Instance Just a representation, NOT actual JavaScript syntax! JavaScript does NOT support real classes like represented here New object created from the class. Like a real house created from an abstract blueprint ☝ Conceptual overview: it works a bit differently in JavaScript. Still important to understand!
  • 5.
    THE 4 FUNDAMENTALOOP PRINCIPLES Abstraction Polymorphism Inheritance Encapsulation The 4 fundamental principles of Object- Oriented Programming 🤔 “How do we actually design classes? How do we model real-world data into classes?”
  • 6.
    PRINCIPLE 1: ABSTRACTION Polymorphism Inheritance Abstraction Encapsulation 👉Abstraction: Ignoring or hiding details that don’t matter, allowing us to get an overview perspective of the thing we’re implementing, instead of messing with details that don’t really matter to our implementation. Real phone Abstracted phone Do we really need all these low-level details? Details have been abstracted away
  • 7.
    PRINCIPLE 2: ENCAPSULATION Polymorphism Inheritance Again,NOT actually JavaScript syntax (the private keyword doesn’t exist) Abstraction Encapsulation 👉 Encapsulation: Keeping properties and methods private inside the class, so they are not accessible from outside the class. Some methods can be exposed as a public interface (API). NOT accessible from outside the class! STILL accessible from within the class! NOT accessible from outside the class! STILL accessible from within the class! 👉 Prevents external code from accidentally manipulating internal properties/state 👉 Allows to change internal implementation without the risk of breaking external code WHY?
  • 8.
    PRINCIPLE 3: INHERITANCE Polymorphism Inheritance Abstraction Encapsulation 👉Inheritance: Making all properties and methods of a certain class available to a child class, forming a hierarchical relationship between classes. This allows us to reuse common logic and to model real-world relationships. PARENT CLASS CHILD CLASS INHERITANCE Inherited OWN methods and properties Inherited CHILD CLASS EXTENDS PARENT CLASS
  • 9.
    PRINCIPLE 4: POLYMORPHISM Inheritance Polymorphism Abstraction Encapsulation 👉Polymorphism: A child class can overwrite a method it inherited from a parent class [it’s more complex that that, but enough for our purposes]. PARENT CLASS CHILD CLASS CHILD CLASS INHERITANCE INHERITANCE Own login method, overwriting login method inherited from User