SlideShare a Scribd company logo
JAVASCRIPT
DECORATORS
UNLOCK THE POWER OF
Nir Kaufman
@nirkaufman
Google Developer Expert
Community leader
Principle Consultant @ 500Tech
ngnir.life
Nir Kaufman
Decorators in js
DECORATORS
BASICS
wrapping one piece of
code with another
wrapping one piece of
code with another
Higher-order functions?
http://eloquentjavascript.net/05_higher_order.html
Why use decorators?
add behaviour to
a class, method, property
or parameter
without affecting other
members of the class.
add behaviour to
a class, method, property
or parameter
without affecting other
members of the class.
add behaviour to
a class, method, property
or parameter
without affecting other
members of the class.
add behaviour to
a class, method, property
or parameter
without affecting other
members of the class.
stage 2 proposal
CLASS
DECORATORS
Class decorators takes
constructor
Class decorators takes
constructor
(target) => target;
(target) => target;
function
function
LIVE DEMOTHE SINGLETON CASE
PROPERTY
DECORATORS
Property decorators takes
object
property name
Property decorators takes
object
Key
(target, key) => void;
(target, key) => void;
object
string
property decorators
don’t return.
LIVE DEMOTHE FORMAT CASE
METHOD
DECORATORS
Method decorators takes
object
Key
descriptor
Method decorators takes
object
Key
descriptor
(target, key, descriptor) => descriptor;
(target, key, descriptor) => descriptor;
object
string
object
LIVE DEMOTHE PROTECT CASE
PARAMETER
DECORATORS
Parameter decorators takes
object
Key
Index
Method decorators takes
object
Key
Index
(target, key, index) => void;
(target, key, index) => void;
object
string
number
LIVE DEMOTHE VALIDATOR CASE
PUTTING IT
ALL TOGETHER
LIVE DEMODEPENDENCY INJECTION
REAL WORLD
DECORATOES
https://realpython.com/blog/python/primer-on-python-decorators/
http://www.luigibifulco.it/blog/en/blog/java-decorator-pattern-with-spring
https://angular.io/docs
https://mobx.js.org/best/decorators.html
https://steelsojka.github.io/lodash-decorators/
https://typeorm.github.io/
@nirkaufman
Thank you!

More Related Content

PPTX
Introduction Of Java
PDF
Puppet Camp DC 2014: Continuous Deployment of Dynamic Environments Using Hier...
PDF
JS Fest 2019/Autumn. Daniel Ostrovsky. Falling in love with decorators ES6/Ty...
PPTX
Decorators | TypeScript | Angular2 Decorators
PPTX
Python Decorators
PPTX
Decorator Pattern presentation theory and examples
PPTX
Decorator Pattern 2.pptxdsadsadsadsadasdasdsa
PDF
Decorator Pattern | Object Oriented Design Pattern
Introduction Of Java
Puppet Camp DC 2014: Continuous Deployment of Dynamic Environments Using Hier...
JS Fest 2019/Autumn. Daniel Ostrovsky. Falling in love with decorators ES6/Ty...
Decorators | TypeScript | Angular2 Decorators
Python Decorators
Decorator Pattern presentation theory and examples
Decorator Pattern 2.pptxdsadsadsadsadasdasdsa
Decorator Pattern | Object Oriented Design Pattern

Similar to Decorators in js (10)

PPTX
Decorator Pattern
PDF
Decorators Lightning Talk for Triangle JavaScript
PPTX
Decorator design pattern
PPTX
Design pattern reading group – decorator pattern
PPTX
Decorators.pptx
PPTX
Decorator design pattern
PDF
Standardizing JavaScript Decorators in TC39 (Full Stack Fest 2019)
PPTX
java training in chennai
PDF
Advanced Python Techniques: Decorators
PPTX
Advanced Python : Decorators
Decorator Pattern
Decorators Lightning Talk for Triangle JavaScript
Decorator design pattern
Design pattern reading group – decorator pattern
Decorators.pptx
Decorator design pattern
Standardizing JavaScript Decorators in TC39 (Full Stack Fest 2019)
java training in chennai
Advanced Python Techniques: Decorators
Advanced Python : Decorators
Ad

More from Nir Kaufman (20)

PDF
Angular Dependency Injection
PDF
Angular Prestige: Less-known API and techniques
PDF
Angular CLI custom builders
PDF
Electronic music 101 for developers
PDF
Nestjs MasterClass Slides
PDF
Redux pattens - JSHeroes 2018
PDF
Angular EE - Special Workshop by Nir Kaufman
PDF
Boosting Angular runtime performance
PDF
Styling recipes for Angular components
PDF
Introduction To Angular's reactive forms
PDF
Webstorm
PDF
Redux with angular 2 - workshop 2016
PDF
Angular Pipes Workshop
PDF
Data Structures in javaScript 2015
PDF
redux and angular - up and running
PDF
Angular redux
PDF
How Angular2 Can Improve Your AngularJS Apps Today!
PDF
Angular2 workshop
PDF
Solid angular
PDF
Webpack and angularjs
Angular Dependency Injection
Angular Prestige: Less-known API and techniques
Angular CLI custom builders
Electronic music 101 for developers
Nestjs MasterClass Slides
Redux pattens - JSHeroes 2018
Angular EE - Special Workshop by Nir Kaufman
Boosting Angular runtime performance
Styling recipes for Angular components
Introduction To Angular's reactive forms
Webstorm
Redux with angular 2 - workshop 2016
Angular Pipes Workshop
Data Structures in javaScript 2015
redux and angular - up and running
Angular redux
How Angular2 Can Improve Your AngularJS Apps Today!
Angular2 workshop
Solid angular
Webpack and angularjs
Ad

Recently uploaded (20)

PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
Electronic commerce courselecture one. Pdf
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PPTX
MYSQL Presentation for SQL database connectivity
PDF
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PPTX
Cloud computing and distributed systems.
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PPTX
sap open course for s4hana steps from ECC to s4
PPTX
Spectroscopy.pptx food analysis technology
PPTX
Big Data Technologies - Introduction.pptx
DOCX
The AUB Centre for AI in Media Proposal.docx
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PPTX
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Electronic commerce courselecture one. Pdf
Digital-Transformation-Roadmap-for-Companies.pptx
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
MYSQL Presentation for SQL database connectivity
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
Mobile App Security Testing_ A Comprehensive Guide.pdf
NewMind AI Weekly Chronicles - August'25 Week I
Cloud computing and distributed systems.
20250228 LYD VKU AI Blended-Learning.pptx
sap open course for s4hana steps from ECC to s4
Spectroscopy.pptx food analysis technology
Big Data Technologies - Introduction.pptx
The AUB Centre for AI in Media Proposal.docx
Advanced methodologies resolving dimensionality complications for autism neur...
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
Diabetes mellitus diagnosis method based random forest with bat algorithm
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...

Decorators in js