What’s OOP?
Introducir a OOP
Presentar el vocabulario
Thursday, November 1, 12
Slide 4
Slide 4 text
Object Oriented Programming
Thursday, November 1, 12
Slide 5
Slide 5 text
Programming paradigm
Thursday, November 1, 12
Slide 6
Slide 6 text
Data abstraction
Encapsulation
Messaging
Modularity
Polymorphism
Inheritance
Thursday, November 1, 12
Slide 7
Slide 7 text
Use object based on the real
world
Thursday, November 1, 12
Slide 8
Slide 8 text
Class vs Object
Thursday, November 1, 12
Slide 9
Slide 9 text
Class
A Class defines Objects
Properties
An object characteristic, such as color
Methods
An object capability, such as walk
Thursday, November 1, 12
Slide 10
Slide 10 text
Objects
A instance of a Class
Share properties and behavior
Unique
Thursday, November 1, 12
Slide 11
Slide 11 text
Class
Thursday, November 1, 12
Slide 12
Slide 12 text
Class
Object1
Thursday, November 1, 12
Slide 13
Slide 13 text
Class
Object1 Object2
Thursday, November 1, 12
Slide 14
Slide 14 text
Class
Object1 Object2 Object3
Thursday, November 1, 12
Slide 15
Slide 15 text
Exercise
Thursday, November 1, 12
Slide 16
Slide 16 text
JavaScript OOP
Aplicar JavaScript OOP
Thursday, November 1, 12
Slide 17
Slide 17 text
JavaScript is a
prototypal language
Thursday, November 1, 12
Slide 18
Slide 18 text
Prototype-based
programming
Class free
Classes are not present
Not Object Oriented
Everything is public
Objects inherits from another objects
Thursday, November 1, 12
Slide 19
Slide 19 text
Objects in JavaScript
Thursday, November 1, 12
Slide 20
Slide 20 text
Everything is an object
Thursday, November 1, 12
Slide 21
Slide 21 text
Everything is an object
Arrays
Thursday, November 1, 12
Slide 22
Slide 22 text
Everything is an object
Arrays
Dates
Thursday, November 1, 12
Slide 23
Slide 23 text
Everything is an object
Arrays
Objects
Dates
Thursday, November 1, 12
Slide 24
Slide 24 text
Everything is an object
Arrays
Objects
Dates
Strings
Thursday, November 1, 12
Slide 25
Slide 25 text
Everything is an object
Arrays
Objects
Numbers
Dates
Strings
Thursday, November 1, 12
Slide 26
Slide 26 text
They have methods and
properties
Thursday, November 1, 12
Slide 27
Slide 27 text
Thursday, November 1, 12
Slide 28
Slide 28 text
Thursday, November 1, 12
Slide 29
Slide 29 text
Thursday, November 1, 12
Slide 30
Slide 30 text
Thursday, November 1, 12
Slide 31
Slide 31 text
Custom Objects
Thursday, November 1, 12
Slide 32
Slide 32 text
Thursday, November 1, 12
Slide 33
Slide 33 text
Thursday, November 1, 12
Slide 34
Slide 34 text
Thursday, November 1, 12
Slide 35
Slide 35 text
Thursday, November 1, 12
Slide 36
Slide 36 text
Thursday, November 1, 12
Slide 37
Slide 37 text
Thursday, November 1, 12
Slide 38
Slide 38 text
Thursday, November 1, 12
Slide 39
Slide 39 text
Thursday, November 1, 12
Slide 40
Slide 40 text
Thursday, November 1, 12
Slide 41
Slide 41 text
Not reuse
Thursday, November 1, 12
Slide 42
Slide 42 text
Not reuse
Unique
Thursday, November 1, 12
Slide 43
Slide 43 text
Not reuse
Unique
Singleton
Pattern
Thursday, November 1, 12
Slide 44
Slide 44 text
Exercise
Thursday, November 1, 12
Slide 45
Slide 45 text
Constructors
Thursday, November 1, 12
Slide 46
Slide 46 text
Constructor
Functions
Classes
Create diferents instances ==> Objects
Use new operator
Accepts parameters
Returns an instance ==> Object
Thursday, November 1, 12
Slide 47
Slide 47 text
Thursday, November 1, 12
Slide 48
Slide 48 text
Thursday, November 1, 12
Slide 49
Slide 49 text
Constructor
Has properties and methods
length
constructor
apply()
call()
prototype
Thursday, November 1, 12
Slide 50
Slide 50 text
Thursday, November 1, 12
Slide 51
Slide 51 text
Prototype
Thursday, November 1, 12
Slide 52
Slide 52 text
Prototype
A property
Defines properties and methods to all
instances
Works with new operator
Stored in the memory once
Contain an Object
initial value === empty Object === {}
Thursday, November 1, 12
Slide 53
Slide 53 text
Thursday, November 1, 12
Slide 54
Slide 54 text
Thursday, November 1, 12
Slide 55
Slide 55 text
Thursday, November 1, 12
Slide 56
Slide 56 text
Thursday, November 1, 12
Slide 57
Slide 57 text
Thursday, November 1, 12
Slide 58
Slide 58 text
Thursday, November 1, 12
Slide 59
Slide 59 text
Thursday, November 1, 12
Slide 60
Slide 60 text
Inheritance
Thursday, November 1, 12
Slide 61
Slide 61 text
Inheritance
A new “class” is created from another “class”
Extends functionality
Defines new attributes and methods
A way to reuse code
All Object inherit from Object.prototype
12+ ways to inherits in JS
Thursday, November 1, 12
Slide 62
Slide 62 text
Prototype Chaining
Pseudo-clasical
Thursday, November 1, 12