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.