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ą.