Att tillämpa SOLID principer i Node.js

Single Responsibility Principle(SRP)

Denna princip säger att en klass bara ska ha en anledning att ändra, vilket innebär att varje klass ska utföra en specifik funktion.

Exempel: Hantera användardata och skicka email aviseringar.

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

Open/Closed Principle(OCP)

Denna princip uppmuntrar utökad funktionalitet genom att lägga till ny kod istället för att ändra befintlig kod.

Exempel: Hantera olika betalningsmetoder i en e-handelsapplikation.

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)

Denna princip hävdar att objekt av en härledd klass ska kunna ersättas med objekt av basklassen utan att påverka programmets korrekthet.

Exempel: Hantera geometriska former.

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

nterface Segregation Principle(ISP)

Denna princip rekommenderar att dela upp gränssnitt i mindre för att undvika att tvinga klasser att implementera metoder de inte behöver.

Exempel: Gränssnitt för uppdatering och visning av data.

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

Dependency Inversion Principle(DIP)

Denna princip föreslår att högnivåmoduler inte bör vara beroende av lågnivåmoduler; båda bör bero på abstraktioner.

Exempel: Används dependency injection för att hantera beroenden.

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

Kom ihåg att dessa exempel bara är illustrationer av hur man tillämpar SOLID principerna i Node.js. I praktiken måste du tillämpa dem flexibelt baserat på syftet och omfattningen av ditt projekt.