SOLID मा सिद्धान्तहरू लागू गर्दै Node.js

Single Responsibility Principle(SRP)

यो सिद्धान्तले बताउँछ कि वर्गमा परिवर्तनको एउटा मात्र कारण हुनुपर्छ, जसको अर्थ प्रत्येक वर्गले एक विशेष प्रकार्य प्रदर्शन गर्नुपर्छ।

उदाहरण: प्रयोगकर्ता डेटा व्यवस्थापन र email सूचनाहरू पठाउने।

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

Open/Closed Principle(OCP)

यो सिद्धान्तले विद्यमान कोड परिमार्जन गर्नुको सट्टा नयाँ कोड थपेर कार्यक्षमता विस्तार गर्न प्रोत्साहन गर्छ।

उदाहरण: ई-वाणिज्य अनुप्रयोगमा विभिन्न भुक्तानी विधिहरू ह्यान्डल गर्दै।

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)

यो सिद्धान्तले व्युत्पन्न वर्गका वस्तुहरू कार्यक्रमको शुद्धतालाई असर नगरी आधार वर्गका वस्तुहरूका लागि प्रतिस्थापन गर्न सकिन्छ भनी जोड दिन्छ।

उदाहरण: ज्यामितीय आकारहरू प्रबन्ध गर्नुहोस्।

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

इन्टरफेस पृथकीकरण सिद्धान्त(ISP)

यो सिद्धान्तले इन्टरफेसहरूलाई सानामा विभाजन गर्न सल्लाह दिन्छ ताकि कक्षाहरूलाई उनीहरूलाई आवश्यक नपर्ने विधिहरू लागू गर्न बाध्य पार्नबाट जोगिन।

उदाहरण: डाटा अद्यावधिक र प्रदर्शन गर्नका लागि इन्टरफेसहरू।

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

Dependency Inversion Principle(DIP)

यो सिद्धान्तले सुझाव दिन्छ कि उच्च-स्तर मोड्युलहरू निम्न-स्तर मोड्युलहरूमा निर्भर हुँदैन। दुवै abstraction मा निर्भर हुनुपर्छ।

उदाहरण: dependency injection निर्भरता व्यवस्थापन गर्न प्रयोग गर्दै।

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

SOLID याद गर्नुहोस्, यी उदाहरणहरू मा सिद्धान्तहरू कसरी लागू गर्ने भनेर दृष्टान्त मात्र हुन् Node.js । अभ्यासमा, तपाईंले आफ्नो परियोजनाको उद्देश्य र मापनको आधारमा तिनीहरूलाई लचिलो रूपमा लागू गर्न आवश्यक छ।