paint-brush
सर्वश्रेष्ठ कॉम्प्लेक्स फ्रंटएंड आर्किटेक्चर: फ़ीचर-स्लाइस्ड डिज़ाइन के बारे में आपको क्या जानना चाहिएद्वारा@mmmidas
2,370 रीडिंग
2,370 रीडिंग

सर्वश्रेष्ठ कॉम्प्लेक्स फ्रंटएंड आर्किटेक्चर: फ़ीचर-स्लाइस्ड डिज़ाइन के बारे में आपको क्या जानना चाहिए

द्वारा Yan Levin8m2024/01/18
Read on Terminal Reader
Read this story w/o Javascript

बहुत लंबा; पढ़ने के लिए

यह आलेख फ़ीचर-स्लाइस्ड डिज़ाइन आर्किटेक्चर पर चर्चा करता है, क्योंकि, मेरी राय में, यह उपलब्ध विकल्पों में से सबसे अच्छा है। यह एफएसडी के विचार और इस वास्तुशिल्प पद्धति द्वारा हल की जाने वाली समस्याओं का भी पता लगाता है।
featured image - सर्वश्रेष्ठ कॉम्प्लेक्स फ्रंटएंड आर्किटेक्चर: फ़ीचर-स्लाइस्ड डिज़ाइन के बारे में आपको क्या जानना चाहिए
Yan Levin HackerNoon profile picture
0-item
1-item
2-item

परिचय

फ्रंटएंड डेवलपर्स को अक्सर एप्लिकेशन आर्किटेक्चर से संबंधित समस्या का सामना करना पड़ता है। इसके लिए एक ऐसे आर्किटेक्चर के उपयोग की आवश्यकता होती है जो आसानी से स्केल कर सके और एप्लिकेशन मॉड्यूल के बीच ढीली युग्मन और उच्च सामंजस्य प्रदान कर सके।


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


हम एफएसडी की तुलना शास्त्रीय और मॉड्यूलर आर्किटेक्चर से करेंगे और उनके पेशेवरों और विपक्षों की जांच करेंगे।


सबसे पहले और सबसे महत्वपूर्ण, आइए तीन अवधारणाओं को अलग करें: परत, टुकड़ा और खंड।

परतें, टुकड़े, खंड

परतें

परतें शीर्ष-स्तरीय निर्देशिकाएं हैं और अनुप्रयोग अपघटन का पहला स्तर हैं। वे संख्या में सीमित हैं - अधिकतम 7 परतें - और मानकीकृत हैं, हालांकि उनमें से कुछ वैकल्पिक हैं।


वर्तमान में, निम्नलिखित परतें प्रतिष्ठित हैं:

परतें प्रत्येक परत का अपना उत्तरदायित्व क्षेत्र होता है और यह व्यवसाय-उन्मुख होता है। आइए प्रत्येक परत पर अलग से विचार करें।


  • ऐप: यह वह जगह है जहां एप्लिकेशन लॉजिक को आरंभ किया जाता है। प्रदाता, राउटर, वैश्विक शैलियाँ, वैश्विक प्रकार की घोषणाएँ आदि को यहाँ परिभाषित किया गया है। यह एप्लिकेशन के लिए प्रवेश बिंदु के रूप में कार्य करता है।


  • प्रक्रियाएँ: यह परत उन प्रक्रियाओं को संभालती है जो कई पृष्ठों तक फैली होती हैं, जैसे मल्टीस्टेप पंजीकरण। इस परत को बहिष्कृत माना जाता है लेकिन फिर भी कभी-कभी इसका सामना किया जा सकता है। यह एक वैकल्पिक परत है.


  • पेज: इस परत में एप्लिकेशन के पेज शामिल हैं।


  • विजेट: ये पृष्ठों पर उपयोग किए जाने वाले स्टैंडअलोन यूआई घटक हैं।


  • विशेषताएं: यह परत उपयोगकर्ता परिदृश्यों और कार्यक्षमता से संबंधित है जो व्यावसायिक मूल्य रखती है। उदाहरण के लिए, पसंद करना, समीक्षा लिखना, उत्पादों को रेटिंग देना आदि। यह एक वैकल्पिक परत है।


  • संस्थाएँ: यह परत व्यावसायिक संस्थाओं का प्रतिनिधित्व करती है। इन संस्थाओं में उपयोगकर्ता, समीक्षाएँ, टिप्पणियाँ आदि शामिल हो सकते हैं। यह एक वैकल्पिक परत है।


  • साझा: इस परत में पुन: प्रयोज्य घटक और उपयोगिताएँ शामिल हैं जो विशिष्ट व्यावसायिक तर्क से बंधे नहीं हैं। इसमें यूआई किट, एक्सियोस कॉन्फ़िगरेशन, एप्लिकेशन कॉन्फ़िगरेशन, सहायक जो व्यावसायिक तर्क से बंधे नहीं हैं, आदि शामिल हैं।


ये परतें कोडबेस को व्यवस्थित करने और मॉड्यूलर, रखरखाव योग्य और स्केलेबल आर्किटेक्चर को बढ़ावा देने में मदद करती हैं।

जीथब परतें

फ़ीचर-स्लाइस्ड डिज़ाइन की प्रमुख विशेषताओं में से एक इसकी पदानुक्रमित संरचना है। इस संरचना में, संस्थाएँ सुविधाओं से कार्यक्षमता का उपयोग नहीं कर सकती हैं क्योंकि सुविधाएँ पदानुक्रम में उच्चतर हैं।


इसी तरह, सुविधाएँ विजेट या प्रक्रियाओं से घटकों का उपयोग नहीं कर सकती हैं, क्योंकि ऊपर की परतें केवल नीचे की परतों का उपयोग कर सकती हैं। यह एक रैखिक प्रवाह को बनाए रखने के लिए किया जाता है जो केवल एक दिशा में निर्देशित होता है। परतें संरचना पदानुक्रम में एक परत जितनी नीचे स्थित होगी, उसमें परिवर्तन करना उतना ही जोखिम भरा होगा क्योंकि कोड में इसका उपयोग अधिक स्थानों पर होने की संभावना है। उदाहरण के लिए, साझा परत में यूआई किट का उपयोग सुविधाओं, विजेट्स और यहां तक कि पेज परतों में भी किया जाता है।

स्लाइस

प्रत्येक परत में, उपनिर्देशिकाएँ होती हैं - स्लाइस - अनुप्रयोग अपघटन का दूसरा स्तर। स्लाइस में, कनेक्शन अमूर्त चीज़ों से नहीं बल्कि विशिष्ट व्यावसायिक संस्थाओं से है। स्लाइस का मुख्य लक्ष्य कोड को उसके मूल्य के आधार पर समूहित करना है।


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


निकट से संबंधित टुकड़ों को एक निर्देशिका में संरचनात्मक रूप से समूहीकृत किया जा सकता है, लेकिन उन्हें अन्य स्लाइस के समान अलगाव नियमों का पालन करना होगा - इस निर्देशिका में कोड तक कोई साझा पहुंच नहीं होनी चाहिए।

स्लाइस

सेगमेंट

प्रत्येक स्लाइस में खंड होते हैं। सेगमेंट कोड को उसके उद्देश्य के आधार पर एक स्लाइस में विभाजित करने में मदद करते हैं। टीम के समझौतों के आधार पर, खंड संरचना और नामकरण में बदल सकते हैं। निम्नलिखित खंड अधिक सामान्यतः उपयोग किए जाते हैं:


  • एपीआई - आवश्यक सर्वर अनुरोध।


  • यूआई - स्लाइस के यूआई घटक।


  • मॉडल - व्यावसायिक तर्क, यानी, राज्य के साथ बातचीत। उदाहरण के लिए, क्रियाएँ और चयनकर्ता।
  • lib - स्लाइस के भीतर प्रयुक्त सहायक कार्यक्षमता।


  • कॉन्फिग - स्लाइस का आवश्यक कॉन्फ़िगरेशन, लेकिन कॉन्फिग सेगमेंट शायद ही कभी सामने आता है।


  • स्थिरांक - आवश्यक स्थिरांक।

सार्वजनिक एपीआई

प्रत्येक स्लाइस और सेगमेंट में एक सार्वजनिक एपीआई है। सार्वजनिक एपीआई को एक इंडेक्स.जेएस या इंडेक्स.टीएस फ़ाइल द्वारा दर्शाया जाता है, जो स्लाइस या सेगमेंट से केवल आवश्यक कार्यक्षमता को बाहर निकालने और अनावश्यक कार्यक्षमता को अलग करने की अनुमति देता है। इंडेक्स फ़ाइल एक प्रवेश बिंदु के रूप में कार्य करती है।


सार्वजनिक एपीआई के लिए नियम:


  • एप्लिकेशन स्लाइस और सेगमेंट केवल स्लाइस की कार्यक्षमता और घटकों का उपयोग करते हैं जो सार्वजनिक एपीआई इंडेक्स फ़ाइल में परिभाषित हैं।


  • स्लाइस या सेगमेंट का आंतरिक भाग जो सार्वजनिक एपीआई में परिभाषित नहीं है, उसे अलग माना जाता है और केवल स्लाइस या सेगमेंट के भीतर ही पहुंच के लिए खुला होता है।


सार्वजनिक एपीआई आयात और निर्यात के साथ काम करना सरल बनाता है, इसलिए एप्लिकेशन में परिवर्तन करते समय, कोड में हर जगह आयात को बदलने की आवश्यकता नहीं होती है।

सार्वजनिक एपीआई

वास्तुकला में गहराई से

अमूर्तन और व्यावसायिक तर्क

परत जितनी ऊंची होगी, वह उतना ही अधिक विशिष्ट व्यावसायिक नोड से बंधी होगी और उसमें उतने ही अधिक व्यावसायिक तर्क होंगे। परत जितनी निचली होगी, परत में उतनी ही अधिक अमूर्तता, पुन: प्रयोज्यता और स्वायत्तता की कमी होगी।

परतों का अमूर्तन

एफएसडी समस्या का समाधान कैसे करता है?

फ़ीचर-स्लाइस्ड डिज़ाइन के कार्यों में से एक ढीला युग्मन और उच्च सामंजस्य प्राप्त करना है। यह समझना महत्वपूर्ण है कि एफएसडी इस परिणाम को कैसे प्राप्त करता है।


OOP में, इन समस्याओं को बहुरूपता , एनकैप्सुलेशन , वंशानुक्रम और अमूर्तता जैसी अवधारणाओं के माध्यम से लंबे समय से हल किया गया है। ये अवधारणाएं कोड के अलगाव, पुन: प्रयोज्यता और बहुमुखी प्रतिभा को सुनिश्चित करती हैं, जहां किसी घटक या कार्यक्षमता का उपयोग कैसे किया जाता है इसके आधार पर विभिन्न परिणाम प्राप्त होते हैं।


फ़ीचर-स्लाइस्ड डिज़ाइन इन सिद्धांतों को फ्रंटएंड में लागू करने में मदद करता है।


अमूर्तता और बहुरूपता परतों के माध्यम से प्राप्त की जाती है। चूँकि निचली परतें अमूर्त होती हैं, इसलिए उन्हें उच्च परतों में पुन: उपयोग किया जा सकता है, और स्थितियों के आधार पर, एक घटक या कार्यक्षमता निर्दिष्ट मापदंडों या प्रॉप्स के आधार पर अलग-अलग तरीके से काम कर सकती है।


इनकैप्सुलेशन को सार्वजनिक एपीआई के माध्यम से प्राप्त किया जाता है, जो स्लाइस और सेगमेंट में बाहर से आवश्यक चीज़ों को अलग करता है। किसी स्लाइस के आंतरिक खंडों तक पहुंच प्रतिबंधित है, और सार्वजनिक एपीआई किसी स्लाइस या सेगमेंट से कार्यक्षमता और घटकों तक पहुंचने का एकमात्र तरीका है।


विरासत भी परतों के माध्यम से प्राप्त की जाती है, क्योंकि उच्च परतें निचली परतों का पुन: उपयोग कर सकती हैं।

क्लासिक वास्तुकला के साथ तुलना

मेरा मानना है कि आपने कई बार क्लासिक वास्तुकला देखी होगी। इसकी सरलता के कारण अधिकांश लेखक शैक्षिक लेखों और यूट्यूब वीडियो में इसका उपयोग करते हैं। शास्त्रीय वास्तुकला के लिए कोई विशिष्ट मानक नहीं है। हालाँकि, अक्सर आप निम्न प्रारूप देख सकते हैं:

क्लासिक वास्तुकला क्लासिक वास्तुकला में उल्लेखनीय कमियाँ हैं। सबसे बड़ी बात यह है कि घटकों और मॉड्यूल अव्यवस्था के बीच अंतर्निहित कनेक्शन के कारण परियोजना को बनाए रखना मुश्किल हो जाता है। क्लासिक वास्तुकला की कमियाँ समय के साथ और अधिक स्पष्ट हो जाती हैं। प्रोजेक्ट जितना लंबा विकसित होता है, एप्लिकेशन आर्किटेक्चर उतना ही उलझ जाता है जिसे सुलझाना मुश्किल होता है।


क्लासिक वास्तुकला चल रहे रखरखाव या पालतू परियोजनाओं के बिना छोटी परियोजनाओं के लिए उपयुक्त है।

फ़ीचर-स्लाइस्ड डिज़ाइन, इसकी अवधारणाओं और मानकों के लिए धन्यवाद, क्लासिक वास्तुकला की समस्याओं को रोकता है।


हालाँकि, FSD के साथ काम करने वाले डेवलपर्स की समझ और कौशल का स्तर क्लासिक आर्किटेक्चर के साथ काम करने की तुलना में अधिक होना चाहिए। आमतौर पर, 2 साल से कम अनुभव वाले डेवलपर्स ने एफएसडी के बारे में नहीं सुना है।


हालाँकि, फ़ीचर-स्लाइस्ड डिज़ाइन के साथ काम करते समय, समस्याओं को "बाद में" के बजाय "अभी" संबोधित करने की आवश्यकता होती है। कोड में मुद्दे और अवधारणाओं से विचलन तुरंत स्पष्ट हो जाते हैं

सरल मॉड्यूलर वास्तुकला के साथ तुलना

सरल मॉड्यूलर वास्तुकला में कई कमियां हैं:

  • कभी-कभी यह अस्पष्ट होता है कि मॉड्यूल या घटकों में कार्यक्षमता कहाँ रखी जाए।


  • किसी अन्य मॉड्यूल के भीतर मॉड्यूल का उपयोग करने में कठिनाइयाँ।


  • व्यावसायिक संस्थाओं के भंडारण से जुड़ी समस्याएं.


  • वैश्विक कार्यों में अंतर्निहित निर्भरताएँ, जिससे एक पेचीदा संरचना उत्पन्न होती है।


ऐसा लगता है कि किसी भी जटिल या मध्यम जटिल परियोजनाओं में, साधारण मॉड्यूलर आर्किटेक्चर की तुलना में फ़ीचर-स्लाइस्ड डिज़ाइन को प्राथमिकता दी जानी चाहिए। एफएसडी कई बुनियादी वास्तुशिल्प समस्याओं का समाधान करता है और इसमें कुछ कमियां भी हैं।


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

फ़ीचर-स्लाइस्ड डिज़ाइन की क्षमता

एफएसडी एक युवा वास्तुशिल्प पद्धति है। हालाँकि, इसका उपयोग पहले से ही कई बैंकिंग, फिनटेक, बी2बी, ई-कॉमर्स कंपनियों और अन्य द्वारा किया जा रहा है। यहां कंपनियों की सूची के साथ GitHub मुद्दे का एक लिंक दिया गया है: GitHub जारी


इस लेख को प्रकाशित करने के समय आधिकारिक FSD दस्तावेज़ के साथ GitHub रिपॉजिटरी में 1.1k से अधिक सितारे थे। दस्तावेज़ीकरण का सक्रिय रूप से विस्तार किया जा रहा है, और टेलीग्राम और डिस्कॉर्ड में एफएसडी विकास टीम और समुदाय वास्तुकला से संबंधित प्रश्नों वाले लोगों की सहायता के लिए 24/7 उपलब्ध हैं।


इस वास्तुकला की क्षमता को अत्यधिक महत्व दिया जाता है, और इसका उपयोग दुनिया भर में बड़ी कंपनियों के बीच व्यापक रूप से फैला हुआ है। उचित रूप से अपनाने के साथ, एफएसडी में फ्रंटएंड विकास के क्षेत्र में प्रमुख वास्तुशिल्प समाधान बनने की क्षमता है।

वास्तुकला के फायदे और नुकसान

लाभ

  • आर्किटेक्चर घटकों को आसानी से बदला, जोड़ा या हटाया जा सकता है


  • वास्तुकला का मानकीकरण


  • अनुमापकता


  • कार्यप्रणाली विकास स्टैक से स्वतंत्र है।


  • अप्रत्याशित दुष्प्रभावों के बिना मॉड्यूल के बीच नियंत्रित और स्पष्ट कनेक्शन।


  • व्यवसाय उन्मुख वास्तुशिल्प पद्धति।

नुकसान

  • कई अन्य वास्तुशिल्प समाधानों की तुलना में एक उच्च प्रवेश बाधा।


  • जागरूकता, टीम संस्कृति और अवधारणाओं का पालन आवश्यक है।


  • चुनौतियों और मुद्दों का समाधान बाद में करने के बजाय तुरंत करने की जरूरत है। कोड की समस्याएं और अवधारणाओं से विचलन तुरंत दिखाई देते हैं। हालाँकि, इसे एक फायदे के तौर पर भी देखा जा सकता है।

निष्कर्ष

फ़ीचर-स्लाइस्ड डिज़ाइन एक दिलचस्प और मूल्यवान खोज है जिसे फ्रंटएंड डेवलपर्स को जानना चाहिए और उपयोग करने में सक्षम होना चाहिए। एफएसडी टीमों को एक लचीली, मानकीकृत और स्केलेबल वास्तुकला और विकास संस्कृति प्रदान कर सकता है। हालाँकि, कार्यप्रणाली के सकारात्मक पहलुओं का उपयोग करने के लिए टीम के भीतर ज्ञान, जागरूकता और अनुशासन की आवश्यकता होती है।


एफएसडी अपने स्पष्ट व्यावसायिक अभिविन्यास, इकाई परिभाषा, कार्यात्मक संरचना और एप्लिकेशन के घटकों की संरचना के कारण अन्य आर्किटेक्चर के बीच में खड़ा है।


आप स्वतंत्र रूप से परियोजनाओं में एफएसडी उपयोग के उदाहरण और आधिकारिक फ़ीचर-स्लाइस्ड डिज़ाइन दस्तावेज़ीकरण का भी पता लगा सकते हैं:


आधिकारिक दस्तावेज़ीकरण

उदाहरण। गिटहब क्लाइंट

उदाहरण। नाइके स्नीकर और जूते की दुकान

उदाहरण। सुडोकू


यह पोस्ट लंबी हो सकती है, लेकिन मुझे आशा है कि आपने कुछ नया सीखा होगा। मैं सराहना करता हूं कि आपने यह पोस्ट पढ़ ली है।


यदि आपके कोई विचार या प्रश्न हैं, तो बेझिझक एक टिप्पणी छोड़ें!


यहाँ भी प्रकाशित किया गया