Aplicarea SOLID principiilor în Node.js

Single Responsibility Principle(SRP)

Acest principiu prevede că o clasă ar trebui să aibă un singur motiv de schimbare, adică fiecare clasă ar trebui să îndeplinească o anumită funcție.

Exemplu: gestionarea datelor utilizatorului și trimiterea email notificărilor.

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

Open/Closed Principle(OCP)

Acest principiu încurajează extinderea funcționalității prin adăugarea de cod nou, mai degrabă decât prin modificarea codului existent.

Exemplu: gestionarea diferitelor metode de plată într-o aplicație de comerț electronic.

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)

Acest principiu afirmă că obiectele unei clase derivate ar trebui să fie substituibile cu obiectele clasei de bază fără a afecta corectitudinea programului.

Exemplu: gestionarea formelor geometrice.

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;  
  }  
}  

Principiul de segregare a interfeței(ISP)

Acest principiu recomandă împărțirea interfețelor în altele mai mici pentru a evita forțarea claselor să implementeze metode de care nu au nevoie.

Exemplu: Interfețe pentru actualizarea și afișarea datelor.

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

Dependency Inversion Principle(DIP)

Acest principiu sugerează că modulele de nivel înalt nu ar trebui să depindă de modulele de nivel scăzut; ambele ar trebui să depindă de abstracții.

Exemplu: Utilizarea dependency injection pentru a gestiona dependențe.

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

Amintiți-vă, aceste exemple sunt doar ilustrări ale modului de aplicare a SOLID principiilor în Node.js. În practică, va trebui să le aplicați în mod flexibil, în funcție de scopul și amploarea proiectului dvs.