एक्सप्रेसजेएस - सर्वश्रेष्ठ अभ्यास

Django और रेलों के विपरीत जो चीजों को करने का एक परिभाषित तरीका है, फ़ाइल संरचना, आदि, एक्सप्रेस परिभाषित तरीके का पालन नहीं करता है। इसका मतलब है कि आप जिस तरह से चाहें आवेदन को संरचना कर सकते हैं। लेकिन जैसे-जैसे आपका एप्लिकेशन आकार में बढ़ता है, इसे बनाए रखना बहुत मुश्किल है, अगर इसमें एक अच्छी तरह से परिभाषित संरचना नहीं है। इस अध्याय में, हम अपने अनुप्रयोगों के निर्माण के लिए आमतौर पर उपयोग की जाने वाली निर्देशिका संरचनाओं और चिंताओं को अलग करने पर ध्यान देंगे।

सबसे पहले, हम नोड और एक्सप्रेस एप्लिकेशन बनाने के लिए सर्वोत्तम प्रथाओं पर चर्चा करेंगे।

  • हमेशा एक नोड परियोजना का उपयोग शुरू करें npm init

  • हमेशा एक के साथ निर्भरता स्थापित करें --save या --save-dev। यह सुनिश्चित करेगा कि यदि आप किसी भिन्न प्लेटफ़ॉर्म पर जाते हैं, तो आप सभी निर्भरताएँ स्थापित करने के लिए npm स्थापित कर सकते हैं ।

  • लोअरकेस फ़ाइल नाम और कैमलकेस चर के साथ छड़ी। यदि आप किसी npm मॉड्यूल को देखते हैं, तो इसका नाम लोअरकेस में रखा गया है और डैश के साथ अलग किया गया है। जब भी आपको इन मॉड्यूल की आवश्यकता होती है, तो camelCase का उपयोग करें।

  • अपनी रिपॉजिटरी में नोड_मॉड्यूल्स को पुश न करें। इसके बजाय npm विकास मशीनों पर सब कुछ स्थापित करता है।

  • का उपयोग config चर स्टोर करने के लिए फ़ाइल

  • अपनी फ़ाइल में समूह और अलग-अलग मार्ग। उदाहरण के लिए, उन फिल्मों के उदाहरण में CRUD ऑपरेशन लें, जिन्हें हमने REST API पेज में देखा था।

निर्देशिका संरचना

अब 'Express' डायरेक्टरी स्ट्रक्चर पर चर्चा करते हैं।

वेबसाइटें

एक्सप्रेस में एप्लिकेशन बनाने के लिए सामुदायिक परिभाषित संरचना नहीं है। निम्नलिखित एक वेबसाइट के लिए एक प्रमुख रूप से इस्तेमाल परियोजना संरचना है।

test-project/
   node_modules/
   config/
      db.js                //Database connection and configuration
      credentials.js       //Passwords/API keys for external services used by your app
      config.js            //Other environment variables
   models/                 //For mongoose schemas
      users.js
      things.js
   routes/                 //All routes for different entities in different files 
      users.js
      things.js
   views/
      index.pug
      404.pug
        ...
   public/                 //All static content being served
      images/
      css/
      javascript/
   app.js
   routes.js               //Require all routes in this and then require this file in 
   app.js 
   package.json

एक्सप्रेस के साथ वेबसाइट बनाने के लिए अन्य दृष्टिकोण भी हैं। आप MVC डिज़ाइन पैटर्न का उपयोग करके एक वेबसाइट बना सकते हैं। अधिक जानकारी के लिए, आप निम्न लिंक पर जा सकते हैं।

https://code.tutsplus.com/tutorials/build-a-complete-mvc-website-with-expressjs--net-34168

तथा,

https://www.terlici.com/2014/08/25/best-practices-express-structure.html।

रेस्टफुल एपीआई

एपीआई डिजाइन करने के लिए सरल हैं; उन्हें एक सार्वजनिक या एक दृश्य निर्देशिका की आवश्यकता नहीं है। एपीआई बनाने के लिए निम्न संरचना का उपयोग करें -

test-project/
   node_modules/
   config/
      db.js                //Database connection and configuration
      credentials.js       //Passwords/API keys for external services used by your app
   models/                 //For mongoose schemas
      users.js
      things.js
   routes/                 //All routes for different entities in different files 
      users.js
      things.js
   app.js
   routes.js               //Require all routes in this and then require this file in 
   app.js 
   package.json

आप एक समान संरचना प्राप्त करने के लिए एक तुर्क जनरेटर का उपयोग भी कर सकते हैं ।