SlideShare ist ein Scribd-Unternehmen logo
1 von 30
Downloaden Sie, um offline zu lesen
Name | @twitter #hashtag | url:slides.com
Object Creation
Patterns in JavaScript
Bobby Bryant
Name | @twitter #hashtag | url:slides.com
About Me
• Web Engineer at 10up
• Father of 3
• JavaScript Junkie
Name | @twitter #hashtag | url:slides.com
Why Cover such a
weird topic?
Name | @twitter #hashtag | url:slides.com
–Kyle Simpson @getify
“Where it takes a pretty in-depth knowledge of a
language like C or C++ to write a full-scale
program, full-scale production JavaScript can,
and often does, barely scratch the surface of
what the language can do.”
https://github.com/getify/You-Dont-Know-JS
Name | @twitter #hashtag | url:slides.com
Classical vs Prototypal
Inheritance
Name | @twitter #hashtag | url:slides.com
Classical Inheritance
• Allows you to create new objects using a class as a blueprint.
• A blueprint as a few characteristics that make it distinct.
• It implies that if you follow the instruction you will
successfully create your object.
• Class Based languages are built around the concept of:
• Building base classes.
• Extending the base classes to build a hierarchy of
inheritance.
Name | @twitter #hashtag | url:slides.com
Classical Inheritance
• Class Based languages are built around the
concept of:
• Building Base Classes.
• Extending the base classes to build a hierarchy of
inheritance.
Name | @twitter #hashtag | url:slides.com
Prototypal Inheritance
• A prototype is one step farther than a blueprint.
• It implies that you have a working version of
something.
• It not a contract that says if you follow these steps
you will have a working object.
• It implies that, “here is a working object, use it as is
or make copies if you want.”
Name | @twitter #hashtag | url:slides.com
How Does JavaScript
use these prototypes?
Name | @twitter #hashtag | url:slides.com
Name | @twitter #hashtag | url:slides.com
Lots of them
Name | @twitter #hashtag | url:slides.com
Understanding the
Prototype
Name | @twitter #hashtag | url:slides.com
Prototypal Inheritance
Name | @twitter #hashtag | url:slides.com
Prototypal Inheritance
Name | @twitter #hashtag | url:slides.com
Static Methods
Name | @twitter #hashtag | url:slides.com
Constructor
Name | @twitter #hashtag | url:slides.com
Extending a Prototype
Name | @twitter #hashtag | url:slides.com
Object Literal
Name | @twitter #hashtag | url:slides.com
Delegation
Name | @twitter #hashtag | url:slides.com
Delegation
Name | @twitter #hashtag | url:slides.com
Object Creation
Patterns
Name | @twitter #hashtag | url:slides.com
Object.create
Name | @twitter #hashtag | url:slides.com
Factory Function
Name | @twitter #hashtag | url:slides.com
Factory Fn #2
Name | @twitter #hashtag | url:slides.com
Composition vs
Inheritance
Name | @twitter #hashtag | url:slides.com
Currently in the larger JS world, there is actually
a completely different paradigm growing.
Functional Programming. And at its core
functional programming is about Composition
over Inheritance.
Name | @twitter #hashtag | url:slides.com
Object.assign
Name | @twitter #hashtag | url:slides.com
Object.assign
Name | @twitter #hashtag | url:slides.com
Composition
Name | @twitter #hashtag | url:slides.com
Is class syntax in ECMAScript 6 just a
syntactic sugar for classical prototypes?
https://www.quora.com/Is-class-syntax-in-ECMAScript-6-just-a-
syntactic-sugar-for-classical-prototypes

Weitere ähnliche Inhalte

Andere mochten auch

भारत के प्रधानमंत्रियों की सूची विकिपीडिया
भारत के प्रधानमंत्रियों की सूची   विकिपीडियाभारत के प्रधानमंत्रियों की सूची   विकिपीडिया
भारत के प्रधानमंत्रियों की सूची विकिपीडिया
kaushal9274
 

Andere mochten auch (20)

Paco tipos de inflacion 2
Paco tipos de inflacion 2Paco tipos de inflacion 2
Paco tipos de inflacion 2
 
Mnemotechnics from neuroscience point of view
Mnemotechnics from neuroscience point of viewMnemotechnics from neuroscience point of view
Mnemotechnics from neuroscience point of view
 
Final CV
Final CVFinal CV
Final CV
 
भारत के प्रधानमंत्रियों की सूची विकिपीडिया
भारत के प्रधानमंत्रियों की सूची   विकिपीडियाभारत के प्रधानमंत्रियों की सूची   विकिपीडिया
भारत के प्रधानमंत्रियों की सूची विकिपीडिया
 
Investigation of Roller Burnishing Process Parameters on Surface Roughness of...
Investigation of Roller Burnishing Process Parameters on Surface Roughness of...Investigation of Roller Burnishing Process Parameters on Surface Roughness of...
Investigation of Roller Burnishing Process Parameters on Surface Roughness of...
 
Andbank opinión corporativa y estrategia de inversión 2017
Andbank opinión corporativa y estrategia de inversión 2017Andbank opinión corporativa y estrategia de inversión 2017
Andbank opinión corporativa y estrategia de inversión 2017
 
The Gas Value Chain – Improvement Opportunities
The Gas Value Chain – Improvement OpportunitiesThe Gas Value Chain – Improvement Opportunities
The Gas Value Chain – Improvement Opportunities
 
Disneyland Park
Disneyland Park Disneyland Park
Disneyland Park
 
Intelligent Water Networks and the Internet of Things (IoT) - Korea Style
Intelligent Water Networks and the Internet of Things (IoT) - Korea StyleIntelligent Water Networks and the Internet of Things (IoT) - Korea Style
Intelligent Water Networks and the Internet of Things (IoT) - Korea Style
 
Reinventing Electric Utility Business Models
Reinventing Electric Utility Business ModelsReinventing Electric Utility Business Models
Reinventing Electric Utility Business Models
 
Dolmen Hotel Malta - MICE Presentation
Dolmen Hotel Malta - MICE Presentation Dolmen Hotel Malta - MICE Presentation
Dolmen Hotel Malta - MICE Presentation
 
Vinita Singh PPT
Vinita Singh PPTVinita Singh PPT
Vinita Singh PPT
 
A New Approach to Healthcare Security
A New Approach to Healthcare SecurityA New Approach to Healthcare Security
A New Approach to Healthcare Security
 
Pengobatan Tradisional dan Komplementer
Pengobatan Tradisional dan KomplementerPengobatan Tradisional dan Komplementer
Pengobatan Tradisional dan Komplementer
 
Zurich Marriott Hotel - MICE Presentation 2017
Zurich Marriott Hotel - MICE Presentation 2017Zurich Marriott Hotel - MICE Presentation 2017
Zurich Marriott Hotel - MICE Presentation 2017
 
MPE DMC Malta - MICE Presentation 2017
MPE DMC Malta - MICE Presentation 2017MPE DMC Malta - MICE Presentation 2017
MPE DMC Malta - MICE Presentation 2017
 
تفريد التعليم المحاضرة الثانية عشر
 تفريد التعليم المحاضرة الثانية عشر تفريد التعليم المحاضرة الثانية عشر
تفريد التعليم المحاضرة الثانية عشر
 
Pengobatan Tradisional dan Komplementer
Pengobatan Tradisional dan KomplementerPengobatan Tradisional dan Komplementer
Pengobatan Tradisional dan Komplementer
 
شرح الويبلي
 شرح الويبلي  شرح الويبلي
شرح الويبلي
 
VMworld 2015: Monitoring and Managing Applications with vRealize Operations 6...
VMworld 2015: Monitoring and Managing Applications with vRealize Operations 6...VMworld 2015: Monitoring and Managing Applications with vRealize Operations 6...
VMworld 2015: Monitoring and Managing Applications with vRealize Operations 6...
 

Ähnlich wie Word camp c bus 2016

When to use Machine Learning Models in SEO and Which ones to use - Lazarina S...
When to use Machine Learning Models in SEO and Which ones to use - Lazarina S...When to use Machine Learning Models in SEO and Which ones to use - Lazarina S...
When to use Machine Learning Models in SEO and Which ones to use - Lazarina S...
LazarinaStoyanova
 
Lect-5--JavaScript-Intro-12032024-105816am.pptx
Lect-5--JavaScript-Intro-12032024-105816am.pptxLect-5--JavaScript-Intro-12032024-105816am.pptx
Lect-5--JavaScript-Intro-12032024-105816am.pptx
zainm7032
 
Chapter15-Presentation.pptx
Chapter15-Presentation.pptxChapter15-Presentation.pptx
Chapter15-Presentation.pptx
GFRomano
 

Ähnlich wie Word camp c bus 2016 (20)

How to not blow up spaceships
How to not blow up spaceshipsHow to not blow up spaceships
How to not blow up spaceships
 
When to use Machine Learning Models in SEO and Which ones to use - Lazarina S...
When to use Machine Learning Models in SEO and Which ones to use - Lazarina S...When to use Machine Learning Models in SEO and Which ones to use - Lazarina S...
When to use Machine Learning Models in SEO and Which ones to use - Lazarina S...
 
HTML Semantic Tags
HTML Semantic TagsHTML Semantic Tags
HTML Semantic Tags
 
Untangling - fall2017 - week 9
Untangling - fall2017 - week 9Untangling - fall2017 - week 9
Untangling - fall2017 - week 9
 
Lect-5--JavaScript-Intro-12032024-105816am.pptx
Lect-5--JavaScript-Intro-12032024-105816am.pptxLect-5--JavaScript-Intro-12032024-105816am.pptx
Lect-5--JavaScript-Intro-12032024-105816am.pptx
 
Chapter15-Presentation.pptx
Chapter15-Presentation.pptxChapter15-Presentation.pptx
Chapter15-Presentation.pptx
 
Apache CloudStack Google Summer of Code
Apache CloudStack Google Summer of CodeApache CloudStack Google Summer of Code
Apache CloudStack Google Summer of Code
 
TechSEO Boost 2021 - Rendering Strategies: Measuring the Devil’s Details in C...
TechSEO Boost 2021 - Rendering Strategies: Measuring the Devil’s Details in C...TechSEO Boost 2021 - Rendering Strategies: Measuring the Devil’s Details in C...
TechSEO Boost 2021 - Rendering Strategies: Measuring the Devil’s Details in C...
 
Doing More with Less: Automated, High-Quality Content Generation
Doing More with Less: Automated, High-Quality Content GenerationDoing More with Less: Automated, High-Quality Content Generation
Doing More with Less: Automated, High-Quality Content Generation
 
Curtin University Frontend Web Development
Curtin University Frontend Web DevelopmentCurtin University Frontend Web Development
Curtin University Frontend Web Development
 
GitHub & Stack Overflow Recruiting
GitHub & Stack Overflow RecruitingGitHub & Stack Overflow Recruiting
GitHub & Stack Overflow Recruiting
 
[DevDay2018] Javascript on the Rise - By Trang Tran, Co-founder & Manager at ...
[DevDay2018] Javascript on the Rise - By Trang Tran, Co-founder & Manager at ...[DevDay2018] Javascript on the Rise - By Trang Tran, Co-founder & Manager at ...
[DevDay2018] Javascript on the Rise - By Trang Tran, Co-founder & Manager at ...
 
2019-04-17 Bio-IT World G Suite-Jira Cloud Sample Tracking
2019-04-17 Bio-IT World G Suite-Jira Cloud Sample Tracking2019-04-17 Bio-IT World G Suite-Jira Cloud Sample Tracking
2019-04-17 Bio-IT World G Suite-Jira Cloud Sample Tracking
 
How to Optimize Your Drupal Site with Structured Content
How to Optimize Your Drupal Site with Structured ContentHow to Optimize Your Drupal Site with Structured Content
How to Optimize Your Drupal Site with Structured Content
 
Rapid and Responsive - UX to Prototype with Bootstrap
Rapid and Responsive - UX to Prototype with BootstrapRapid and Responsive - UX to Prototype with Bootstrap
Rapid and Responsive - UX to Prototype with Bootstrap
 
Learning Web Development with Ruby on Rails Launch
Learning Web Development with Ruby on Rails LaunchLearning Web Development with Ruby on Rails Launch
Learning Web Development with Ruby on Rails Launch
 
How to Use Social Media for Recruiting
How to Use Social Media for RecruitingHow to Use Social Media for Recruiting
How to Use Social Media for Recruiting
 
Instagram filters (8 24)
Instagram filters (8 24)Instagram filters (8 24)
Instagram filters (8 24)
 
User Experience Bootcamp for Developers
User Experience Bootcamp for DevelopersUser Experience Bootcamp for Developers
User Experience Bootcamp for Developers
 
Semantic web assignment 3
Semantic web assignment 3Semantic web assignment 3
Semantic web assignment 3
 

Kürzlich hochgeladen

VIP Call Girls Himatnagar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Himatnagar 7001035870 Whatsapp Number, 24/07 BookingVIP Call Girls Himatnagar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Himatnagar 7001035870 Whatsapp Number, 24/07 Booking
dharasingh5698
 
💚😋 Bilaspur Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
💚😋 Bilaspur Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋💚😋 Bilaspur Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
💚😋 Bilaspur Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
nirzagarg
 
Low Sexy Call Girls In Mohali 9053900678 🥵Have Save And Good Place 🥵
Low Sexy Call Girls In Mohali 9053900678 🥵Have Save And Good Place 🥵Low Sexy Call Girls In Mohali 9053900678 🥵Have Save And Good Place 🥵
Low Sexy Call Girls In Mohali 9053900678 🥵Have Save And Good Place 🥵
Chandigarh Call girls 9053900678 Call girls in Chandigarh
 
Call Girls in Prashant Vihar, Delhi 💯 Call Us 🔝9953056974 🔝 Escort Service
Call Girls in Prashant Vihar, Delhi 💯 Call Us 🔝9953056974 🔝 Escort ServiceCall Girls in Prashant Vihar, Delhi 💯 Call Us 🔝9953056974 🔝 Escort Service
Call Girls in Prashant Vihar, Delhi 💯 Call Us 🔝9953056974 🔝 Escort Service
9953056974 Low Rate Call Girls In Saket, Delhi NCR
 
Thalassery Escorts Service ☎️ 6378878445 ( Sakshi Sinha ) High Profile Call G...
Thalassery Escorts Service ☎️ 6378878445 ( Sakshi Sinha ) High Profile Call G...Thalassery Escorts Service ☎️ 6378878445 ( Sakshi Sinha ) High Profile Call G...
Thalassery Escorts Service ☎️ 6378878445 ( Sakshi Sinha ) High Profile Call G...
Call Girls In Delhi Whatsup 9873940964 Enjoy Unlimited Pleasure
 
6.High Profile Call Girls In Punjab +919053900678 Punjab Call GirlHigh Profil...
6.High Profile Call Girls In Punjab +919053900678 Punjab Call GirlHigh Profil...6.High Profile Call Girls In Punjab +919053900678 Punjab Call GirlHigh Profil...
6.High Profile Call Girls In Punjab +919053900678 Punjab Call GirlHigh Profil...
@Chandigarh #call #Girls 9053900678 @Call #Girls in @Punjab 9053900678
 
💚😋 Salem Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
💚😋 Salem Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋💚😋 Salem Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
💚😋 Salem Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
nirzagarg
 
VIP Call Girls Pollachi 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Pollachi 7001035870 Whatsapp Number, 24/07 BookingVIP Call Girls Pollachi 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Pollachi 7001035870 Whatsapp Number, 24/07 Booking
dharasingh5698
 

Kürzlich hochgeladen (20)

Pirangut | Call Girls Pune Phone No 8005736733 Elite Escort Service Available...
Pirangut | Call Girls Pune Phone No 8005736733 Elite Escort Service Available...Pirangut | Call Girls Pune Phone No 8005736733 Elite Escort Service Available...
Pirangut | Call Girls Pune Phone No 8005736733 Elite Escort Service Available...
 
𓀤Call On 7877925207 𓀤 Ahmedguda Call Girls Hot Model With Sexy Bhabi Ready Fo...
𓀤Call On 7877925207 𓀤 Ahmedguda Call Girls Hot Model With Sexy Bhabi Ready Fo...𓀤Call On 7877925207 𓀤 Ahmedguda Call Girls Hot Model With Sexy Bhabi Ready Fo...
𓀤Call On 7877925207 𓀤 Ahmedguda Call Girls Hot Model With Sexy Bhabi Ready Fo...
 
Busty Desi⚡Call Girls in Vasundhara Ghaziabad >༒8448380779 Escort Service
Busty Desi⚡Call Girls in Vasundhara Ghaziabad >༒8448380779 Escort ServiceBusty Desi⚡Call Girls in Vasundhara Ghaziabad >༒8448380779 Escort Service
Busty Desi⚡Call Girls in Vasundhara Ghaziabad >༒8448380779 Escort Service
 
VIP Call Girls Himatnagar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Himatnagar 7001035870 Whatsapp Number, 24/07 BookingVIP Call Girls Himatnagar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Himatnagar 7001035870 Whatsapp Number, 24/07 Booking
 
APNIC Updates presented by Paul Wilson at ARIN 53
APNIC Updates presented by Paul Wilson at ARIN 53APNIC Updates presented by Paul Wilson at ARIN 53
APNIC Updates presented by Paul Wilson at ARIN 53
 
Katraj ( Call Girls ) Pune 6297143586 Hot Model With Sexy Bhabi Ready For S...
Katraj ( Call Girls ) Pune  6297143586  Hot Model With Sexy Bhabi Ready For S...Katraj ( Call Girls ) Pune  6297143586  Hot Model With Sexy Bhabi Ready For S...
Katraj ( Call Girls ) Pune 6297143586 Hot Model With Sexy Bhabi Ready For S...
 
Wadgaon Sheri $ Call Girls Pune 10k @ I'm VIP Independent Escorts Girls 80057...
Wadgaon Sheri $ Call Girls Pune 10k @ I'm VIP Independent Escorts Girls 80057...Wadgaon Sheri $ Call Girls Pune 10k @ I'm VIP Independent Escorts Girls 80057...
Wadgaon Sheri $ Call Girls Pune 10k @ I'm VIP Independent Escorts Girls 80057...
 
💚😋 Bilaspur Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
💚😋 Bilaspur Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋💚😋 Bilaspur Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
💚😋 Bilaspur Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
 
Low Sexy Call Girls In Mohali 9053900678 🥵Have Save And Good Place 🥵
Low Sexy Call Girls In Mohali 9053900678 🥵Have Save And Good Place 🥵Low Sexy Call Girls In Mohali 9053900678 🥵Have Save And Good Place 🥵
Low Sexy Call Girls In Mohali 9053900678 🥵Have Save And Good Place 🥵
 
Call Girls in Prashant Vihar, Delhi 💯 Call Us 🔝9953056974 🔝 Escort Service
Call Girls in Prashant Vihar, Delhi 💯 Call Us 🔝9953056974 🔝 Escort ServiceCall Girls in Prashant Vihar, Delhi 💯 Call Us 🔝9953056974 🔝 Escort Service
Call Girls in Prashant Vihar, Delhi 💯 Call Us 🔝9953056974 🔝 Escort Service
 
Thalassery Escorts Service ☎️ 6378878445 ( Sakshi Sinha ) High Profile Call G...
Thalassery Escorts Service ☎️ 6378878445 ( Sakshi Sinha ) High Profile Call G...Thalassery Escorts Service ☎️ 6378878445 ( Sakshi Sinha ) High Profile Call G...
Thalassery Escorts Service ☎️ 6378878445 ( Sakshi Sinha ) High Profile Call G...
 
6.High Profile Call Girls In Punjab +919053900678 Punjab Call GirlHigh Profil...
6.High Profile Call Girls In Punjab +919053900678 Punjab Call GirlHigh Profil...6.High Profile Call Girls In Punjab +919053900678 Punjab Call GirlHigh Profil...
6.High Profile Call Girls In Punjab +919053900678 Punjab Call GirlHigh Profil...
 
VVIP Pune Call Girls Sinhagad WhatSapp Number 8005736733 With Elite Staff And...
VVIP Pune Call Girls Sinhagad WhatSapp Number 8005736733 With Elite Staff And...VVIP Pune Call Girls Sinhagad WhatSapp Number 8005736733 With Elite Staff And...
VVIP Pune Call Girls Sinhagad WhatSapp Number 8005736733 With Elite Staff And...
 
Real Men Wear Diapers T Shirts sweatshirt
Real Men Wear Diapers T Shirts sweatshirtReal Men Wear Diapers T Shirts sweatshirt
Real Men Wear Diapers T Shirts sweatshirt
 
APNIC Policy Roundup, presented by Sunny Chendi at the 5th ICANN APAC-TWNIC E...
APNIC Policy Roundup, presented by Sunny Chendi at the 5th ICANN APAC-TWNIC E...APNIC Policy Roundup, presented by Sunny Chendi at the 5th ICANN APAC-TWNIC E...
APNIC Policy Roundup, presented by Sunny Chendi at the 5th ICANN APAC-TWNIC E...
 
💚😋 Salem Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
💚😋 Salem Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋💚😋 Salem Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
💚😋 Salem Escort Service Call Girls, 9352852248 ₹5000 To 25K With AC💚😋
 
Story Board.pptxrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr
Story Board.pptxrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrStory Board.pptxrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr
Story Board.pptxrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr
 
Pune Airport ( Call Girls ) Pune 6297143586 Hot Model With Sexy Bhabi Ready...
Pune Airport ( Call Girls ) Pune  6297143586  Hot Model With Sexy Bhabi Ready...Pune Airport ( Call Girls ) Pune  6297143586  Hot Model With Sexy Bhabi Ready...
Pune Airport ( Call Girls ) Pune 6297143586 Hot Model With Sexy Bhabi Ready...
 
Shikrapur - Call Girls in Pune Neha 8005736733 | 100% Gennuine High Class Ind...
Shikrapur - Call Girls in Pune Neha 8005736733 | 100% Gennuine High Class Ind...Shikrapur - Call Girls in Pune Neha 8005736733 | 100% Gennuine High Class Ind...
Shikrapur - Call Girls in Pune Neha 8005736733 | 100% Gennuine High Class Ind...
 
VIP Call Girls Pollachi 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Pollachi 7001035870 Whatsapp Number, 24/07 BookingVIP Call Girls Pollachi 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Pollachi 7001035870 Whatsapp Number, 24/07 Booking
 

Word camp c bus 2016

  • 1. Name | @twitter #hashtag | url:slides.com Object Creation Patterns in JavaScript Bobby Bryant
  • 2. Name | @twitter #hashtag | url:slides.com About Me • Web Engineer at 10up • Father of 3 • JavaScript Junkie
  • 3. Name | @twitter #hashtag | url:slides.com Why Cover such a weird topic?
  • 4. Name | @twitter #hashtag | url:slides.com –Kyle Simpson @getify “Where it takes a pretty in-depth knowledge of a language like C or C++ to write a full-scale program, full-scale production JavaScript can, and often does, barely scratch the surface of what the language can do.” https://github.com/getify/You-Dont-Know-JS
  • 5. Name | @twitter #hashtag | url:slides.com Classical vs Prototypal Inheritance
  • 6. Name | @twitter #hashtag | url:slides.com Classical Inheritance • Allows you to create new objects using a class as a blueprint. • A blueprint as a few characteristics that make it distinct. • It implies that if you follow the instruction you will successfully create your object. • Class Based languages are built around the concept of: • Building base classes. • Extending the base classes to build a hierarchy of inheritance.
  • 7. Name | @twitter #hashtag | url:slides.com Classical Inheritance • Class Based languages are built around the concept of: • Building Base Classes. • Extending the base classes to build a hierarchy of inheritance.
  • 8. Name | @twitter #hashtag | url:slides.com Prototypal Inheritance • A prototype is one step farther than a blueprint. • It implies that you have a working version of something. • It not a contract that says if you follow these steps you will have a working object. • It implies that, “here is a working object, use it as is or make copies if you want.”
  • 9. Name | @twitter #hashtag | url:slides.com How Does JavaScript use these prototypes?
  • 10. Name | @twitter #hashtag | url:slides.com
  • 11. Name | @twitter #hashtag | url:slides.com Lots of them
  • 12. Name | @twitter #hashtag | url:slides.com Understanding the Prototype
  • 13. Name | @twitter #hashtag | url:slides.com Prototypal Inheritance
  • 14. Name | @twitter #hashtag | url:slides.com Prototypal Inheritance
  • 15. Name | @twitter #hashtag | url:slides.com Static Methods
  • 16. Name | @twitter #hashtag | url:slides.com Constructor
  • 17. Name | @twitter #hashtag | url:slides.com Extending a Prototype
  • 18. Name | @twitter #hashtag | url:slides.com Object Literal
  • 19. Name | @twitter #hashtag | url:slides.com Delegation
  • 20. Name | @twitter #hashtag | url:slides.com Delegation
  • 21. Name | @twitter #hashtag | url:slides.com Object Creation Patterns
  • 22. Name | @twitter #hashtag | url:slides.com Object.create
  • 23. Name | @twitter #hashtag | url:slides.com Factory Function
  • 24. Name | @twitter #hashtag | url:slides.com Factory Fn #2
  • 25. Name | @twitter #hashtag | url:slides.com Composition vs Inheritance
  • 26. Name | @twitter #hashtag | url:slides.com Currently in the larger JS world, there is actually a completely different paradigm growing. Functional Programming. And at its core functional programming is about Composition over Inheritance.
  • 27. Name | @twitter #hashtag | url:slides.com Object.assign
  • 28. Name | @twitter #hashtag | url:slides.com Object.assign
  • 29. Name | @twitter #hashtag | url:slides.com Composition
  • 30. Name | @twitter #hashtag | url:slides.com Is class syntax in ECMAScript 6 just a syntactic sugar for classical prototypes? https://www.quora.com/Is-class-syntax-in-ECMAScript-6-just-a- syntactic-sugar-for-classical-prototypes