Design Patterns
github.com/otaviopace
Otávio Pace
O que são?
São soluções estabelecidas para problemas recorrentes do desenvolvimento de software
Um exemplo
const penguin = new Animal(
// Chordata Phylum
new Phylum({
Subkingdom: 'Eumetazoa',
Clade: ['Bilateria', 'Nephrozoa'],
Superphylum: 'Deuterostomia',
}),
// Aves Class
new Class({
Clade: 'Ornithurae',
}),
// Sphenisciformes Order
new Order('Sphenisciformes'),
// Spheniscidae Family
new Family('Spheniscidae'),
// Species
'Eudyptula'
)
const penguin = new PenguinFactory('Eudyptula')
Mas de onde eles vieram?
Christopher Alexander
data:image/s3,"s3://crabby-images/01a02/01a0254d0e712776f01308170ed4b2f415f85b23" alt=""
Kent Beck
data:image/s3,"s3://crabby-images/374a1/374a19d70aa9f8a858866d0a6315342fb5cfd9e7" alt=""
Ward Cunningham
data:image/s3,"s3://crabby-images/d83fc/d83fc2770749721943b93bcc4bed5de7057c7094" alt=""
data:image/s3,"s3://crabby-images/3c443/3c443c5b57565e5040ca1c76e994a5789c70356b" alt=""
data:image/s3,"s3://crabby-images/02c86/02c8667f81d118107631d63142451021c08bca10" alt=""
Gang of Four
E eles ainda são aplicáveis?
Sim!
As vezes não sabemos nem por onde começar ao tentar resolver um problema
Exemplo de memorização
class Calculator {
doExpensiveCalculation () {
return 1 + 1
}
}
const calculator = new Calculator()
calculator.doExpensiveCalculation() // calculates 2
calculator.doExpensiveCalculation() // calculates 2
class Calculator {
doExpensiveCalculation () {
return 1 + 1
}
}
class CalculatorDecorator {
constructor () {
this.hasCalculated = false
this.realCalculator = new Calculator()
}
doExpensiveCalculation () {
if (!this.hasCalculated) {
this.result = this.realCalculator
.doExpensiveCalculation()
this.hasCalculated = true
return this.result
}
return this.result
}
}
const calculator = new Calculator()
calculator.doExpensiveCalculation() // calculates 2
calculator.doExpensiveCalculation() // calculates 2
const decorator = new CalculatorDecorator()
decorator.doExpensiveCalculation() // calculates 2
decorator.doExpensiveCalculation() // gets cache of 2
Contribuir a outros projetos
data:image/s3,"s3://crabby-images/67ed4/67ed48e9c4eb8983403897db1435fbe404dcb05e" alt=""
data:image/s3,"s3://crabby-images/c5665/c56654ee0ae9bdcc63d351cc0c7dc9ed018b9359" alt=""
Fácil entendimento de código
data:image/s3,"s3://crabby-images/a37fe/a37fea96a256bb4f5d48c672ef0ac98bc9ee4a93" alt=""
Cuidado!
data:image/s3,"s3://crabby-images/10cb3/10cb31ab231e0bcb6eb1656738a2e59911558bb3" alt=""
Se seu time não sabe design patterns, isso pode dificultar a legibilidade
Não tente utilizar um pattern para resolver um problema que ele não foi feito para resolver
O abuso dos patterns pode complicar mais o código
data:image/s3,"s3://crabby-images/169e4/169e474e9d5f820f75d15a3cc330eda41ead3079" alt=""
Strategy Pattern!
class Potato {
constructor () {
this.foodName = 'potato'
}
setCookStrategy (cookStrategy) {
this.cookStrategy = cookStrategy
}
cook () {
this.cookStrategy.cook(this.foodName)
}
}
class Boiled {
cook (foodName) {
console.log(`Boiling ${foodName}!`)
}
}
class Fried {
cook (foodName) {
console.log(`Frying ${foodName}!`)
}
}
const potato = new Potato()
potato.setCookStrategy(new Boiled())
potato.cook() // Boiling potato!
potato.setCookStrategy(new Fried())
potato.cook() // Frying potato!
Chain of Responsibility Pattern!
class Padawan {
constructor () {
this.master = new Knight()
}
fight (monster) {
if (monster.strength > 10) {
console.log('I am too weak for this :(')
return this.callMasterToFight(monster)
}
this.punch()
}
callMasterToFight (monster) {
this.master.fight(monster)
}
punch () {
console.log('A weak padawan punch!')
}
}
class Knight {
constructor () {
this.master = new Master()
}
fight (monster) {
if (monster.strength > 100) {
console.log('I am too weak for this :(')
return this.callMasterToFight(monster)
}
this.swingLightSaber()
}
callMasterToFight (monster) {
this.master.fight(monster)
}
swingLightSaber () {
console.log('Schvrmmmmmmm!')
}
}
class Master {
fight (monster) {
this.useTheForce()
}
callMasterToFight (monster) {
throw new Error('I am the ultimate master!')
}
useTheForce () {
console.log('You\'re finished!')
}
}
const weakMonster = { strength: 7 }
const padawan = new Padawan()
padawan.fight(weakMonster)
// Padawan: A weak padawan punch!
const averageMonster = { strength: 60 }
padawan.fight(averageMonster)
// Padawan: I am too weak for this :(
// Knight: Schvrmmmmmmm!
const ultraMonster = { strength: 560 }
padawan.fight(ultraMonster)
// Padawan: I am too weak for this :(
// Knight: I am too weak for this :(
// Master: You're finished!
📚Referências
https://github.com/otaviopace/design-patterns
data:image/s3,"s3://crabby-images/ec625/ec6256ae07413d729f30bfd69ab1ca7b3c25dd55" alt=""
🏜️
Obrigado!
data:image/s3,"s3://crabby-images/43f6b/43f6b1584572b8d4bca65b48e3df5870745b2493" alt=""
Design Patterns
By otaviopace
Design Patterns
- 1,001