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.