SOLID Principų taikymas Node.js

Single Responsibility Principle(SRP)

Šis principas teigia, kad klasė turi turėti tik vieną priežastį keistis, ty kiekviena klasė turi atlikti tam tikrą funkciją.

Pavyzdys: vartotojo duomenų tvarkymas ir email pranešimų siuntimas.

class UserManager {  
  constructor() {}  
    
  createUser(userData) {  
    // Logic for creating a user  
  }  
}  
  
class EmailService {  
  constructor() {}  
    
  sendEmail(emailData) {  
    // Logic for sending an email  
  }  
}  

Open/Closed Principle(OCP)

Šis principas skatina išplėsti funkcionalumą pridedant naują kodą, o ne keičiant esamą kodą.

Pavyzdys: skirtingų mokėjimo būdų tvarkymas el. prekybos programoje.

class PaymentProcessor {  
  processPayment() {  
    // Common logic for payment processing  
  }  
}  
  
class CreditCardPaymentProcessor extends PaymentProcessor {  
  processPayment() {  
    // Logic for processing credit card payment  
  }  
}  
  
class PayPalPaymentProcessor extends PaymentProcessor {  
  processPayment() {  
    // Logic for processing PayPal payment  
  }  
}  

Liskov Substitution Principle(LSP)

Šis principas teigia, kad išvestinės klasės objektai turi būti pakeisti bazinės klasės objektais, nepažeidžiant programos teisingumo.

Pavyzdys: Geometrinių figūrų valdymas.

class Shape {  
  area() {}  
}  
  
class Rectangle extends Shape {  
  constructor(width, height) {}  
    
  area() {  
    return this.width * this.height;  
  }  
}  
  
class Square extends Shape {  
  constructor(side) {}  
    
  area() {  
    return this.side * this.side;  
  }  
}  

sąsajos atskyrimo principas(IPT)

Šis principas pataria suskaidyti sąsajas į mažesnes, kad klasės nebūtų verčiamos įgyvendinti metodus, kurių joms nereikia.

Pavyzdys: sąsajos duomenims atnaujinti ir rodyti.

class UpdateableFeature {  
  updateFeature() {}  
}  
  
class DisplayableFeature {  
  displayFeature() {}  
}  

Dependency Inversion Principle(DIP)

Šis principas rodo, kad aukšto lygio moduliai neturėtų priklausyti nuo žemo lygio modulių; abu turėtų priklausyti nuo abstrakcijų.

Pavyzdys: naudojimas dependency injection priklausomybėms valdyti.

class OrderProcessor {  
  constructor(dbConnection, emailService) {  
    this.dbConnection = dbConnection;  
    this.emailService = emailService;  
  }  
}  

Atminkite, kad šie pavyzdžiai yra tik iliustracijos, kaip taikyti SOLID principus Node.js. Praktiškai turėsite juos taikyti lanksčiai, atsižvelgdami į savo projekto tikslą ir mastą.