EmberJS - त्वरित गाइड

Ember.js क्या है?

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

Ember.js का मूल नाम स्प्राउटकोर MVC फ्रेमवर्क था । यह येहुदा काट्ज़ द्वारा विकसित किया गया था और शुरू में दिसंबर 2011 में जारी किया गया था । Ember.js की स्थिर रिलीज़ 2.10.0 है और यह 28 नवंबर, 2016 को रिलीज़ हुई थी।

क्यों Ember.js?

Ember.js के उपयोग को समझने के लिए निम्नलिखित बिंदुओं पर विचार करें -

  • Ember.js MIT लाइसेंस के तहत एक खुला स्रोत जावास्क्रिप्ट ढांचा है।

  • यह नया बंधन सिंटैक्स का उपयोग प्रदान करता है HTMLBars टेम्पलेट इंजन जो का सुपरसेट है Handerlbars इंजन templating।

  • यह रेंडरिंग गति को बढ़ाने के लिए ग्लिमर रेंडरिंग इंजन प्रदान करता है ।

  • यह कमांड लाइन इंटरफ़ेस उपयोगिता प्रदान करता है जो एम्बर पैटर्न को विकास प्रक्रिया में एकीकृत करता है और डेवलपर उत्पादकता पर आसानी से ध्यान केंद्रित करता है।

  • यह दो गुणों के बीच लिंक बनाने के लिए डेटा बाइंडिंग का समर्थन करता है और जब एक संपत्ति में परिवर्तन होता है, तो दूसरी संपत्ति नए मूल्य के साथ अपग्रेड हो जाएगी।

Ember.js की विशेषताएं

निम्नलिखित Ember.js की सबसे प्रमुख विशेषताओं में से कुछ हैं -

  • Ember.js का उपयोग पुन: प्रयोज्य और बनाए रखने योग्य जावास्क्रिप्ट वेब अनुप्रयोगों के लिए किया जाता है।

  • Ember.js के पास विकास मॉडल के मूल में HTML और CSS हैं

  • यह उदाहरण शुरुआती प्रदान करता है।

  • मार्ग Ember.js की मुख्य विशेषताएं हैं जो URL के प्रबंधन के लिए उपयोग की जाती हैं।

  • Ember.js एम्बर अनुप्रयोगों को डीबग करने के लिए एम्बर इंस्पेक्टर टूल प्रदान करता है ।

  • Ember.js उन टेम्प्लेट का उपयोग करता है, जो एप्लिकेशन की सामग्री बदलने पर स्वचालित रूप से मॉडल को अपडेट करने में मदद करते हैं।

आपके सिस्टम में Ember.js को कॉन्फ़िगर करना आसान है। एम्बर सीएलआई (कमांड लाइन इंटरफेस) उपयोगिता का उपयोग करके, आप अपने एम्बर प्रोजेक्ट बना और प्रबंधित कर सकते हैं। एम्बर सीएलआई विभिन्न प्रकार के अनुप्रयोग परिसंपत्ति प्रबंधन से संबंधित है जैसे कि संघटन, लघुकरण और संस्करणकरण और घटकों, मार्गों आदि के उत्पादन के लिए जनरेटर भी प्रदान करता है।

एम्बर सीएलआई को स्थापित करने के लिए, आपको निम्नलिखित निर्भरताएं होनी चाहिए -

  • Git- यह फाइलों में किए गए परिवर्तनों को ट्रैक करने के लिए एक ओपन सोर्स वर्जन कंट्रोल सिस्टम है। अधिक जानकारी के लिए, आधिकारिक वेबसाइट git की जाँच करें । एम्बर अपनी निर्भरता को प्रबंधित करने के लिए गिट का उपयोग करता है।

    • लिनक्स पर Git का अधिष्ठापन : इस लिंक का उपयोग करके लिनक्स पर Git स्थापित करें -http://git-scm.com/download/linux

    • Mac पर Git इंस्टॉल करना : इस लिंक का उपयोग करके Mac OS पर Git इंस्टॉल करें -https://git-scm.com/download/mac

    • लिनक्स पर Git इंस्टॉल करना : इस लिंक का उपयोग करके विंडोज पर Git इंस्टॉल करें -https://git-scm.com/download/win

  • Node.js and npm- Node.js एक खुला स्रोत है, जिसका उपयोग सर्वर साइड और नेटवर्किंग अनुप्रयोगों के विकास के लिए किया जाता है। यह जावास्क्रिप्ट में लिखा गया है। एनपीएम एक नोड पैकेज प्रबंधक है जो परियोजनाओं में निर्भरता को स्थापित करने, साझा करने और प्रबंधित करने के लिए उपयोग किया जाता है। एम्बर सीएलआई निर्भरता प्राप्त करने के लिए एनओडी.जेएस रन टाइम और एनपीएम का उपयोग करता है।

  • Bower - इसका उपयोग HTML, CSS, जावास्क्रिप्ट, छवि फ़ाइलों आदि जैसे घटकों के प्रबंधन के लिए किया जाता है और इसे npm का उपयोग करके स्थापित किया जा सकता है।

  • Watchman - इस वैकल्पिक निर्भरता का उपयोग फ़ाइलों या निर्देशिकाओं को देखने और कुछ कार्यों को निष्पादित करने के लिए किया जा सकता है जब वे बदलते हैं।

  • PhantomJS - इस वैकल्पिक निर्भरता का उपयोग वेब पेज के साथ बातचीत करने के लिए ब्राउज़र आधारित इकाई परीक्षणों को चलाने के लिए किया जा सकता है।

एम्बर सीएलआई स्थापित करना

एम्बर सीएलआई एम्बर पैटर्न को विकास प्रक्रिया में एकीकृत करता है और डेवलपर उत्पादकता पर आसानी से ध्यान केंद्रित करता है। इसका उपयोग Ember.js और Ember डेटा के साथ Ember ऐप्स बनाने के लिए किया जाता है।

आप npm का उपयोग करके एम्बर स्थापित कर सकते हैं जैसा कि नीचे दी गई कमांड में है -

npm install -g ember-cli

बीटा संस्करण को स्थापित करने के लिए, निम्न कमांड का उपयोग करें -

npm install -g [email protected]

एम्बर की सफल स्थापना की जांच करने के लिए, निम्नलिखित कमांड का उपयोग करें -

ember -v

उपरोक्त कमांड को निष्पादित करने के बाद, यह कुछ इस तरह दिखाएगा -

ember-cli: 2.10.1
node: 0.12.7
os: win32 ia32

Ember.js की मूल अवधारणाएँ हैं -

  • Router
  • Templates
  • Models
  • Components

राउटर और रूट हैंडलर

URL एड्रेस बार में URL दर्ज करके ऐप को लोड करता है और उपयोगकर्ता ऐप के भीतर एक लिंक पर क्लिक करेगा। Ember राउटर का उपयोग URL को रूट हैंडलर में मैप करने के लिए करता है। राउटर मौजूदा URL को उस मार्ग से मिलाता है जो तब डेटा लोड करने, टेम्प्लेट प्रदर्शित करने और एप्लिकेशन स्थिति सेट करने के लिए उपयोग किया जाता है।

रूट हैंडलर निम्नलिखित क्रियाएं करता है -

  • यह टेम्पलेट प्रदान करता है।

  • यह उस मॉडल को परिभाषित करता है जो टेम्पलेट तक पहुंच योग्य होगा।

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

टेम्पलेट्स

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

नमूना

मार्ग संचालकों ने उस मॉडल को प्रस्तुत किया जो वेब सर्वर के लिए जानकारी को बनाए रखता है। यह डेटाबेस में संग्रहीत डेटा में हेरफेर करता है। मॉडल सरल वर्ग है जो एम्बर डेटा की कार्यक्षमता का विस्तार करता है। Ember Data एक लाइब्रेरी है जिसे डेटाबेस में संग्रहीत डेटा के साथ हेरफेर करने के लिए Ember.js के साथ कसकर युग्मित किया जाता है।

अवयव

घटक उपयोगकर्ता इंटरफ़ेस व्यवहार को नियंत्रित करता है जिसमें दो भाग शामिल हैं -

  • एक टेम्पलेट जो जावास्क्रिप्ट में लिखा गया है

  • एक स्रोत फ़ाइल जो जावास्क्रिप्ट में लिखी गई है जो घटकों का व्यवहार प्रदान करती है।

आप अपने सिस्टम में Ember.js को आसानी से कॉन्फ़िगर कर सकते हैं। Ember.js की स्थापना को EmberJS संस्थापन अध्याय में समझाया गया है ।

एप्लिकेशन बनाना

हमें Ember.js का उपयोग करके एक सरल ऐप बनाएं। पहले एक फ़ोल्डर बनाएँ जहाँ आप अपने एप्लिकेशन बनाते हैं। उदाहरण के लिए, यदि आपने "emberjs-app" फ़ोल्डर बनाया है, तो इस फ़ोल्डर में जाएँ -

$ cd ~/emberjs-app

"Emberjs = app" फ़ोल्डर के अंदर, नई कमांड का उपयोग करके एक नया प्रोजेक्ट बनाएं -

$ ember new demo-app

जब आप कोई प्रोजेक्ट बनाते हैं, तो नया कमांड फाइलों और निर्देशिकाओं के साथ निम्नलिखित निर्देशिका संरचना प्रदान करता है -

|-- app
|-- bower_components
|-- config
|-- dist
|-- node_modules
|-- public
|-- tests
|-- tmp
|-- vendor

bower.json
ember-cli-build.js
package.json
README.md
testem.js
  • app - यह मॉडल, मार्गों, घटकों, टेम्पलेट्स और शैलियों के फ़ोल्डर्स और फ़ाइलों को निर्दिष्ट करता है।

  • bower_components / bower.json- इसका उपयोग HTML, CSS, जावास्क्रिप्ट, छवि फ़ाइलों आदि जैसे घटकों के प्रबंधन के लिए किया जाता है और इसे npm का उपयोग करके स्थापित किया जा सकता है। Bower_components निर्देशिका सभी बोवर घटक शामिल हैं और bower.json निर्भरता जो एंबर, एंबर CLI shims और QUnit द्वारा स्थापित कर रहे हैं की सूची है।

  • config- इसमें environment.js डायरेक्टरी है जो किसी एप्लिकेशन की सेटिंग्स को कॉन्फ़िगर करने के लिए उपयोग किया जाता है।

  • dist - इसमें आउटपुट फाइलें शामिल हैं जो ऐप बनाते समय तैनात की जाती हैं।

  • node_modules / package.json- एनपीएम Node.js के लिए एक नोड पैकेज मैनेजर है जो परियोजनाओं में निर्भरता को स्थापित करने, साझा करने और प्रबंधित करने के लिए उपयोग किया जाता है। Package.json फ़ाइल में एक अनुप्रयोग की वर्तमान npm निर्भरताएँ और सूचीबद्ध संकुल शामिल हैंnode_modules निर्देशिका।

  • public - इसमें चित्र, फ़ॉन्ट आदि जैसी संपत्तियां शामिल हैं।

  • vendor - यह एक निर्देशिका है जिसमें जावास्क्रिप्ट के रूप में फ्रंट-एंड निर्भरताएं, सीएसएस को बोवर गो द्वारा नियंत्रित नहीं किया जाता है।

  • tests / testem.js- स्वचालित परीक्षण फ़ोल्डर परीक्षण और परीक्षण धावक के तहत जमा हो जाती है testem की एंबर CLI के में व्यवस्थित किया जाता testem.js

  • tmp - इसमें एम्बर सीएलआई की अस्थायी फाइलें हैं।

  • ember-cli-build.js - यह निर्दिष्ट करता है कि एम्बर सीएलआई का उपयोग करके ऐप कैसे बनाया जाए।

रनिंग एप्लीकेशन

एप्लिकेशन को चलाने के लिए, नई बनाई गई प्रोजेक्ट डायरेक्टरी में नेविगेट करें -

$ cd demo-app

हमने नया प्रोजेक्ट बनाया है और यह नीचे दिए गए कमांड के साथ चलने के लिए तैयार है -

$ ember server

अब ब्राउज़र खोलें और नेविगेट करें http://localhost:4200/। जैसा की नीचे इमेज में दिखाया गया है आपको एम्बर वेलकम पेज मिलेगा -

Ember.js में, सभी ऑब्जेक्ट Ember.Object से लिए गए हैं। ऑब्जेक्ट-ओरिएंटेड एनालिसिस एंड डिजाइन तकनीक को कहा जाता हैobject modeling। Ember.Object क्लास सिस्टम का उपयोग करके मिक्सर और कंस्ट्रक्टर विधियों जैसी सुविधाओं का समर्थन करता है। एम्बर एरे के लिए अवलोकन परिवर्तन देने के लिए जावास्क्रिप्ट ऐरे प्रोटोटाइप का विस्तार करने के लिए एम्बर.न्यूमरेबल इंटरफ़ेस का उपयोग करता है और स्ट्रिंग प्रोटोटाइप का विस्तार करने के लिए प्रारूपण और स्थानीयकरण विधियों का भी उपयोग करता है ।

निम्न तालिका उनके विवरण के साथ Ember.js में विभिन्न प्रकार के ऑब्जेक्ट मॉडल को सूचीबद्ध करती है -

क्र.सं. प्रकार और विवरण
1 कक्षाएं और उदाहरण

क्लास एक टेम्पलेट या ब्लू प्रिंट है, जिसमें चर और कार्यों का एक संग्रह है, जबकि उदाहरण उस वर्ग की वस्तु से संबंधित हैं। आप Ember.Object के विस्तार () पद्धति का उपयोग करके नए एम्बर वर्ग बना सकते हैं ।

2 कक्षाएं और उदाहरण फिर से खोलना

इसे फिर से परिभाषित किए बिना वर्ग कार्यान्वयन को अद्यतन करने के अलावा कुछ नहीं है।

3 संगणित गुण

एक गणना की गई संपत्ति गुणों के रूप में कार्यों की घोषणा करती है और जब जरूरत होती है तो Ember.js स्वचालित रूप से गणना किए गए गुणों को कॉल करता है और एक चर में एक या अधिक गुण जोड़ता है।

4 कम्प्यूटेड गुण और डेटा एकत्र करना

गणना की गई संपत्ति अपने मूल्य को निर्धारित करने के लिए एक सरणी में सभी वस्तुओं तक पहुंचती है।

5 प्रेक्षकों

पर्यवेक्षक संपत्तियों की गणना की गई संपत्तियों का अवलोकन करता है और गणना की गई संपत्ति के पाठ को अद्यतन करता है।

6 बाइंडिंग

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

राउटर EmberJs की एक मुख्य विशेषता है जो URL को टेम्प्लेट की एक श्रृंखला में अनुवादित करता है और एक एप्लिकेशन की स्थिति का प्रतिनिधित्व करता है। Ember राउटर का उपयोग URL को रूट हैंडलर में मैप करने के लिए करता है। राउटर वर्तमान URL को अन्य मार्गों से मिलाता है जो डेटा लोड करने, टेम्प्लेट प्रदर्शित करने और एप्लिकेशन स्थिति सेट करने के लिए उपयोग किए जाते हैं।

रूट हैंडलर कुछ क्रियाएं करता है जैसे -

  • यह टेम्पलेट प्रदान करता है।

  • यह मॉडल को परिभाषित करता है और यह टेम्पलेट के लिए सुलभ होगा।

  • यदि उपयोगकर्ता को किसी ऐप के विशेष भाग पर जाने की अनुमति नहीं है, तो राउटर एक नए मार्ग पर रीडायरेक्ट करेगा।

निम्न तालिका उनके विवरण के साथ Ember.js में विभिन्न राउटरों को सूचीबद्ध करती है -

क्र.सं. प्रकार और विवरण
1 मार्गों को परिभाषित करना

राउटर वर्तमान URL को टेम्प्लेट प्रदर्शित करने, डेटा लोड करने और एप्लिकेशन स्थिति सेट करने के लिए जिम्मेदार मार्गों से मेल खाता है।

2 एक रूट के मॉडल को निर्दिष्ट करना

रूट मॉडल निर्दिष्ट करने के लिए, आपको मॉडल से डेटा प्रदर्शित करने के लिए टेम्पलेट की आवश्यकता होती है।

3 टेम्पलेट रेंडर करना

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

4 पुन: निर्देशित

यह एक URL पुनर्निर्देशन तंत्र है जो अनुरोधित URL नहीं मिलने पर उपयोगकर्ता को एक अलग पृष्ठ पर पुनर्निर्देशित करता है।

5 संक्रमण को रोकना और पुनः प्रयास करना

Transition.abort () और transition.retry () तरीकों गर्भपात और एक मार्ग संक्रमण के दौरान क्रमश: संक्रमण पुन: प्रयास किया जा सकता है।

6 लोड हो रहा है / त्रुटि सबस्टिट्यूट

एम्बर राउटर एक रूट लोडिंग और त्रुटियों की जानकारी प्रदान करता है जो रूट लोड करते समय होती हैं।

7 क्वेरी पैरामीटर

क्वेरी पैरामीटर "दाईं ओर" दृश्य में आते हैं? वैकल्पिक कुंजी-मूल्य जोड़े के रूप में दर्शाए गए URL में चिह्न।

8 अतुल्यकालिक रूटिंग

Ember.js राउटर में एसिंक्रोनस रूटिंग का उपयोग करके किसी एप्लिकेशन के भीतर जटिल async तर्क को संभालने की क्षमता है।

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

नीचे दी गई तालिका में टेम्पलेट्स के बारे में कुछ और जानकारी दी गई है -

क्र.सं. प्रकार और विवरण
1 हैंडलबार्स मूल बातें

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

2 बिल्ट-इन हेल्पर्स

सहायक टेम्पलेटों को अतिरिक्त कार्यक्षमता प्रदान करते हैं और उपयोगकर्ताओं के लिए उचित प्रारूप में मॉडल और घटकों से कच्चे मूल्य को संशोधित करते हैं।

3 सशर्त,

Ember.js दो सशर्त बयानों को परिभाषित करता है जो कार्यक्रम के प्रवाह को नियंत्रित करने में मदद करते हैं।

4 वस्तुओं की सूची प्रदर्शित करना

आप किसी आइटम में #each सहायक का उपयोग करके किसी सरणी में सूची प्रदर्शित कर सकते हैं ।

5 एक वस्तु में कुंजी प्रदर्शित करना

आप ऑब्जेक्ट में कुंजियों को # प्रत्येक-इन हेल्पर का उपयोग करके प्रदर्शित कर सकते हैं ।

6 लिंक

{{लिंक करने}} घटक एक मार्ग के लिए एक लिंक बनाने के लिए इस्तेमाल किया जा सकता है।

7 क्रिया

HTML तत्व को {{क्रिया}} हेल्पर का उपयोग करके क्लिक करने योग्य बनाया जा सकता है ।

8 इनपुट हेल्पर्स

Ember.ss में {{input}} और {{textarea}} सहायकों का उपयोग करके सामान्य रूप नियंत्रण बनाया जा सकता है

9 विकास सहायक

हैंडलबार्स और एम्बर के कुछ सहायकों का उपयोग करके टेम्पलेट डेवलपमेंट को आसान बनाया जा सकता है।

10 लेखन सहायक

आप टेम्प्लेट में अतिरिक्त कार्यक्षमता जोड़ सकते हैं और उपयोगकर्ताओं के लिए मॉडल और घटकों से कच्चे मानों को उचित प्रारूप में परिवर्तित कर सकते हैं।

Ember.js घटक W3C वेब घटक विनिर्देशन का उपयोग करता है और सही इनकैप्सुलेशन UI विजेट प्रदान करता है। इसमें टेम्प्लेट , शैडो डोम और कस्टम तत्वों के रूप में तीन मुख्य विनिर्देश शामिल हैं । घटक को डेटा-टेम्प्लेट-नाम के भीतर घोषित किया जाता है, जिसमें एक सादे स्ट्रिंग के बजाय एक पथ का नाम होता है और "घटकों /" के साथ उपसर्ग होता है।

निम्न तालिका कार्यों की क्रिया घटनाओं को सूचीबद्ध करती है -

क्र.सं. कार्रवाई की घटनाओं और विवरण
1 एक घटक परिभाषित करना

आप Ember.js में एक घटक को आसानी से परिभाषित कर सकते हैं और प्रत्येक घटक के नाम में एक डैश होना चाहिए।

2 घटक जीवनचक्र

घटक के जीवनकाल में किसी घटक के जीवन में विशिष्ट समय पर कोड को निष्पादित करने के लिए कुछ विधियों का उपयोग किया जाता है।

3 एक घटक के लिए गुण पासिंग

घटक सीधे टेम्पलेट दायरे में संपत्ति तक नहीं पहुंचता है। इसलिए, बस घटक गिरावट के समय संपत्ति की घोषणा करें।

4 एक घटक में लपेटकर सामग्री

आप टेम्प्लेट का उपयोग करके सामग्री को घटक में लपेट सकते हैं।

5 एक घटक तत्व को अनुकूलित करना

आप जावास्क्रिप्ट में एम्बर के एक उपवर्ग का उपयोग करके घटक के तत्वों जैसे विशेषताओं, वर्ग नामों को अनुकूलित कर सकते हैं ।

6 ब्लॉक परम का उपयोग करना

एक घटक में पारित गुण एक ब्लॉक अभिव्यक्ति में परिणाम वापस दे सकते हैं।

7 हैंडलिंग घटनाएँ

उपयोगकर्ता की घटनाओं जैसे डबल-क्लिक, होवरिंग, की प्रेस आदि को इवेंट हैंडलर्स द्वारा नियंत्रित किया जा सकता है। ऐसा करने के लिए, घटक पर विधि के रूप में ईवेंट नाम लागू करें।

8 क्रियाओं के साथ परिवर्तन ट्रिगर

अवयव परिवर्तनों को ट्रिगर कर सकते हैं और क्रियाओं का उपयोग करके घटनाओं के साथ संवाद कर सकते हैं।

मॉडल एक ऐसा वर्ग है जो एम्बर डेटा की कार्यक्षमता का विस्तार करता है। जब कोई उपयोगकर्ता पृष्ठ को ताज़ा करता है, तो पृष्ठ की सामग्री को एक मॉडल द्वारा दर्शाया जाना चाहिए। Ember.js में, प्रत्येक मार्ग का एक संबद्ध मॉडल है। मॉडल आवेदन के प्रदर्शन को बेहतर बनाने में मदद करता है। एम्बर डेटा सर्वर में संग्रहीत डेटा में हेरफेर करता है और सॉकेट.आईओ और फायरबेस या वेब स्टोरेज जैसे स्ट्रीमिंग एपीआई के साथ आसानी से काम करता है।

मूल अवधारणा

  • Store
  • Models
  • Records
  • Adapter
  • Caching

दुकान

स्टोर एक आवेदन में उपलब्ध सभी अभिलेखों का केंद्रीय भंडार और कैश है। मार्ग और नियंत्रक आपके एप्लिकेशन के संग्रहीत डेटा तक पहुंच सकते हैं। संपूर्ण ऑब्जेक्ट के बीच डेटा साझा करने के लिए DS.Store स्वचालित रूप से बनाया गया है।

import Ember from 'ember';

export default Ember.Route.extend ({
   model() {
      return this.store.find();
   }
});

मॉडल

मॉडल एक ऐसा वर्ग है जो एम्बर डेटा की कार्यक्षमता का विस्तार करता है, जो अन्य वस्तुओं के साथ संबंधों को निर्दिष्ट करता है। जब कोई उपयोगकर्ता पृष्ठ को ताज़ा करता है, तो पृष्ठ की सामग्री को एक मॉडल द्वारा दर्शाया जाना चाहिए।

import DS from 'ember-data';

export default DS.Model.extend ({
   owner: DS.attr(),
   city: DS.attr()
});

अभिलेख

एक रिकॉर्ड एक मॉडल का एक उदाहरण है जिसमें जानकारी शामिल होती है, जो एक सर्वर से लोड होती है और आप इसके मॉडल प्रकार और आईडी द्वारा रिकॉर्ड की पहचान कर सकते हैं ।

//It finds the record of type 'person' and an 'ID' of 1
this.get('store').findRecord('person', 1); // => { id: 1, name: 'steve-buscemi' }

अनुकूलक

एडेप्टर एक ऐसी वस्तु है, जो एम्बर से अनुरोध किए गए रिकॉर्ड को विशेष सर्वर बैकएंड में उपयुक्त कॉल में अनुवाद करने के लिए जिम्मेदार है। उदाहरण के लिए, यदि आप 1 की आईडी वाले व्यक्ति को ढूंढना चाहते हैं, तो एम्बर HTTP / person / 1 का उपयोग करके URL लोड करेगा ।

कैशिंग

जब आप दूसरी बार सर्वर से रिकॉर्ड लोड करते हैं तो रिकॉर्ड को स्टोर द्वारा स्वचालित रूप से कैश किया जा सकता है और उसी ऑब्जेक्ट उदाहरण को लौटाता है। यह आपके एप्लिकेशन के प्रदर्शन को बेहतर बनाता है और उपयोगकर्ता के लिए एप्लिकेशन UI को जितनी जल्दी हो सके प्रदर्शित करता है।

निम्न तालिका मॉडल के बारे में विवरण नीचे सूचीबद्ध करती है -

क्र.सं. मॉडल तरीके और विवरण
1 मॉडल परिभाषित करना

मॉडल एक साधारण वर्ग है जो एम्बर डेटा की कार्यक्षमता का विस्तार करता है।

2 रिकॉर्ड्स ढूँढना

आप एम्बर डेटा स्टोर का उपयोग करके रिकॉर्ड प्राप्त कर सकते हैं।

3 रिकॉर्ड बनाना और हटाना

आप मॉडल के उदाहरण पर रिकॉर्ड बना और हटा सकते हैं।

4 रिश्तों

Ember.js मॉडल को एक दूसरे से कैसे संबंधित हैं यह निर्दिष्ट करने के लिए संबंध प्रकार प्रदान करता है।

5 स्टोर में रिकॉर्ड्स को पुश करना

आप किसी एप्लिकेशन से रिकॉर्ड का अनुरोध किए बिना रिकॉर्ड को स्टोर की कैश में धकेल सकते हैं।

6 मेटाडाटा को संभालना

मेटाडेटा एक डेटा है जो रिकॉर्ड का उपयोग करने के बजाय विशिष्ट मॉडल या प्रकार के लिए उपयोग किया जाता है।

7 अनुकूलन अनुकूलित करना

Ember.js एडाप्टर निर्दिष्ट करता है कि बैकएंड डेटा स्टोर पर URL फॉर्मेट और REST API हेडर्स पर डेटा कैसे रखा जाता है।

एम्बर एनपीएम और बोवर का उपयोग निर्भरता के प्रबंधन के लिए करता है जो एनपीएम के लिए पैकेज में परिभाषित हैं और बोवर के लिए बोवर.जॉन के लिए। उदाहरण के लिए, आपको अपनी स्टाइल शीट के लिए SASS स्थापित करने की आवश्यकता हो सकती है जो Ember ऐप को विकसित करते समय एम्बर द्वारा स्थापित नहीं है। इसे पूरा करने के लिए, पुन: प्रयोज्य पुस्तकालयों को साझा करने के लिए एम्बर Addons का उपयोग करें । यदि आप किसी भी CSS फ्रेमवर्क या जावास्क्रिप्ट डेटपिस्टरी निर्भरता को स्थापित करना चाहते हैं, तो Bower पैकेज मैनेजर का उपयोग करें।

ऐड-ऑन

एंबर CLI निम्न आदेश का उपयोग करके एंबर ऐड-ऑन स्थापित करने के लिए इस्तेमाल किया जा सकता -

ember install ember-cli-sass

एंबर स्थापित आदेश संबंधित विन्यास फाइल करने के लिए सभी निर्भरता बचत होगी।

कुंज

यह वेब के लिए एक पैकेज प्रबंधक है जो HTML, CSS, जावास्क्रिप्ट या छवि फ़ाइलों के घटकों का प्रबंधन करता है। यह मूल रूप से सभी पैकेजों को बनाए रखता है और उनकी निगरानी करता है और नए अपडेट की जांच करता है। यह एम्बर सीएलआई परियोजना के मूल में रखे गए अनुप्रयोगों पर नज़र रखने के लिए कॉन्फ़िगरेशन फ़ाइल bower.json का उपयोग करता है ।

आप निम्न आदेश का उपयोग करके प्रोजेक्ट निर्भरताएँ स्थापित कर सकते हैं -

bower install <dependencies> --save

संपत्ति

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

AMD जावास्क्रिप्ट मॉड्यूल

आप परिसंपत्ति को पहले तर्क के रूप में और दूसरे तर्क के रूप में मॉड्यूल और निर्यात की सूची दे सकते हैं। आप इन परिसंपत्तियों को एम्बर-क्ली-बिल्ड.js मेनिफ़ेस्ट फ़ाइल में शामिल कर सकते हैं -

app.import('bower_components/ic-ajax/dist/named-amd/main.js', {
   exports: {
      'ic-ajax': [
         'default',
         'defineFixture',
         'lookupFixture',
         'raw',
         'request'
      ]
   }
});

पर्यावरण विशिष्ट संपत्ति

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

app.import ({
   development: 'bower_components/ember/ember.js',
   production:  'bower_components/ember/ember.prod.js'
});

अन्य संपत्तियां

एक बार सभी संपत्तियां सार्वजनिक / फ़ोल्डर में रखने के बाद, उन्हें डिस्ट / डायरेक्टरी में कॉपी कर लिया जाएगा। उदाहरण के लिए, यदि आप सार्वजनिक / छवियों / favicon.ico फ़ोल्डर में रखे गए फ़ेविकॉन की नकल करते हैं, तो यह डिस्ट / इमेज / फ़ेविकॉन.ओको निर्देशिका में कॉपी हो जाएगी । तीसरे पक्ष की संपत्ति को मैन्युअल रूप से विक्रेता / फ़ोल्डर में या आयात () विकल्प के माध्यम से बोवर पैकेज प्रबंधक का उपयोग करके जोड़ा जा सकता है। आयात () विकल्प का उपयोग करके जो संपत्तियां नहीं जोड़ी जाती हैं , वे अंतिम बिल्ड में मौजूद नहीं होंगी।

उदाहरण के लिए, कोड की निम्नलिखित पंक्ति पर विचार करें जो संपत्ति को डिस्टर्ब / फोल्डर में आयात करती है ।

app.import('bower_components/font-awesome/fonts/fontawesome-webfont.ttf');

कोड की उपरोक्त रेखा डिस्ट / फ़ॉन्ट-भयानक / फोंट / fontawesomewebfont.ttf में एक फ़ॉन्ट फ़ाइल बनाती है । आप उपरोक्त फ़ाइल को नीचे दिखाए गए अनुसार एक अलग पथ पर भी रख सकते हैं -

app.import('bower_components/font-awesome/fonts/fontawesome-webfont.ttf', {
   destDir: 'assets'
});

यह डिस्ट / एसेट्स / fontawesome-webfont.ttf में फॉन्ट फाइल को कॉपी करेगा ।

Ember एप्लिकेशन को Ember.Application वर्ग का उपयोग करके बढ़ाया जा सकता है जो आपके ऑब्जेक्ट के निर्माण में सहायक वस्तुओं को घोषित और कॉन्फ़िगर करता है।

एप्लिकेशन को चलाते समय Ember.ApplicationInstance वर्ग बनाता है जिसका उपयोग इसके पहलुओं के प्रबंधन के लिए किया जाता है और यह तात्कालिक वस्तुओं के लिए स्वामी के रूप में कार्य करता है। संक्षेप में, Ember.Application वर्ग अनुप्रयोग को परिभाषित करता है और Ember.ApplicationInstance वर्ग अपने राज्य का प्रबंधन करता है।

निम्न तालिका मॉडल के बारे में अधिक जानकारी नीचे सूचीबद्ध करती है -

क्र.सं. मॉडल तरीके और विवरण
1 निर्भरता अन्तःक्षेपण

यह एक वस्तु की निर्भरता को दूसरे को आपूर्ति करने की प्रक्रिया है और उनके बीच वस्तुओं और निर्भरता वर्गों को घोषित करने और तात्कालिक करने के लिए एक एम्बर एप्लिकेशन द्वारा उपयोग किया जाता है।

2 initializers

आरंभिक का उपयोग किसी एप्लिकेशन को बूट करने के लिए कॉन्फ़िगर करने के लिए किया जाता है।

3 सेवाएं

सेवा एक एम्बर वस्तु है जिसे आवेदन के विभिन्न भागों में उपलब्ध कराया जा सकता है।

4 द रन लूप

यह एक ऐसा क्षेत्र है जहां अधिकांश एप्लिकेशन का आंतरिक कोड होता है।

Ember.js को अनुप्रयोग के वातावरण के प्रबंधन के लिए कॉन्फ़िगर किया जा सकता है। Ember.js को कॉन्फ़िगर करने में निम्नलिखित विषय शामिल हैं -

क्र.सं. कॉन्फ़िगर करने के तरीके और विवरण
1 App और Ember CLI को कॉन्फ़िगर करना

आप एप्लिकेशन के वातावरण के प्रबंधन के लिए एम्बर ऐप और सीएलआई को कॉन्फ़िगर कर सकते हैं।

2 प्रोटोटाइप एक्सटेंशन और निर्दिष्ट URL प्रकार को अक्षम करना

प्रोटोटाइप एक्सटेंशन को EXTEND_PROTOTYPES ध्वज को झूठा और URL प्रकार को निर्दिष्ट करके Ember रूटर विकल्पों का उपयोग करके अक्षम किया जा सकता है ।

3 एंबेडिंग एप्लीकेशन और फ़ीचर फ्लैग्स

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

एम्बर इंस्पेक्टर एक ब्राउज़र ऐड-ऑन है जिसका उपयोग एम्बर एप्लिकेशन को डीबग करने के लिए किया जाता है। एम्बर इंस्पेक्टर में निम्नलिखित विषय शामिल हैं -

क्र.सं. एम्बर इंस्पेक्टर तरीके और विवरण
1 इंस्पेक्टर को स्थापित करना

आप अपने एप्लिकेशन को डीबग करने के लिए एम्बर इंस्पेक्टर को स्थापित कर सकते हैं।

2 वस्तु निरीक्षक

एम्बर निरीक्षक एम्बर वस्तुओं के साथ बातचीत करने की अनुमति देता है।

3 द ट्री

व्यू ट्री किसी एप्लिकेशन की वर्तमान स्थिति प्रदान करता है।

4 निरीक्षण मार्गों, डेटा टैब और लाइब्रेरी जानकारी

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

5 वाद-विवाद वाद-विवाद

एम्बर इंस्पेक्टर अपने राज्यों के आधार पर वादे प्रदान करता है।

6 ऑब्जेक्ट्स और रेंडरिंग प्रदर्शन का निरीक्षण करना

ऑब्जेक्ट इंस्टेंस का निरीक्षण करने के लिए कंटेनर का उपयोग करें और रेंडर प्रदर्शन विकल्प का उपयोग करके एप्लिकेशन के रेंडर समय की गणना करें।