खोज…


परिचय

हम देखेंगे कि कोणीय पर काम करने वाली सेवा कैसे सेट की जाए, जिससे हमारे वेब ऐप को ऑफ़लाइन क्षमताएं मिल सकें।

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

सेवा कार्यकर्ता को हमारे ऐप में जोड़ें

यदि आप mobile.angular.io से परामर्श कर रहे हैं, तो सबसे पहले - अब मोबाइल काम नहीं करता है।

तो शुरू करने के लिए, हम कोणीय क्ली के साथ एक सामान्य परियोजना बना सकते हैं।

ng new serviceWorking-example
cd serviceWorking-example

अब महत्वपूर्ण बात, कोणीय क्लि के लिए कहा गया है कि हम सेवा कार्यकर्ता का उपयोग करना चाहते हैं:

एनजी सेट apps.0.serviceWorker = true

यदि किसी कारण से आपके पास @ कोणीय / सेवा-कार्यकर्ता स्थापित नहीं है, तो आपको एक संदेश दिखाई देगा:

आपकी परियोजना सेवाकार्य = सच के साथ विन्यस्त है, लेकिन @ कोणीय / सेवा-कार्यकर्ता स्थापित नहीं है। npm install --save-dev @angular/service-worker चलाएं और फिर से प्रयास करें, या अपने .angular-cli.json में ng set apps.0.serviceWorker=false चलाएँ।

.Angular-cli.json की जाँच करें और अब आपको यह देखना चाहिए: "serviceWorker": सच है

जब यह ध्वज सत्य होगा, तो उत्पादन बिल्डरों को एक सेवा कार्यकर्ता के साथ स्थापित किया जाएगा।

एक ngsw-default.json फ़ाइल उत्पन्न होगी (या मामले में संवर्धित होने के कारण हमने एक ngsw-घोषणापत्र बनाया है। परियोजना की जड़ में आमतौर पर, यह राउटिंग को निर्दिष्ट करने के लिए किया जाता है, भविष्य में यह संभवतः स्वचालित रूप से किया जाएगा) डिस्ट / रूट में, और सेवा कार्यकर्ता स्क्रिप्ट को वहां कॉपी किया जाएगा। सेवा कार्यकर्ता को पंजीकृत करने के लिए index.html में एक छोटी स्क्रिप्ट जोड़ी जाएगी।

अब अगर हम निर्माण मोड एनपी बिल्ड-prod में एप्लिकेशन का निर्माण करते हैं

और dist / folder को चेक करे।

आपको वहां तीन नई फाइलें दिखाई देंगी:

  • कार्यकर्ता basic.min.js
  • sw-register.HASH.bundle.js
  • ngsw-manifest.json

इसके अलावा, index.html में अब यह स्व-रजिस्टर स्क्रिप्ट शामिल है, जो हमारे लिए एक कोणीय सेवा कार्यकर्ता (ASW) को पंजीकृत करती है।

अपने ब्राउज़र में पृष्ठ को रीफ़्रेश करें (Chrome के लिए वेब सर्वर द्वारा दिया गया)

डेवलपर टूल खोलें। एप्लिकेशन पर जाएं -> सेवा कार्यकर्ता

यहाँ छवि विवरण दर्ज करें

अच्छा अब सेवा कार्यकर्ता ऊपर और चल रहा है!

अब हमारे एप्लिकेशन को तेजी से लोड करना चाहिए और हमें एप्लिकेशन को ऑफ़लाइन उपयोग करने में सक्षम होना चाहिए।

अब यदि आप क्रोम कंसोल में ऑफ़लाइन मोड को सक्षम करते हैं, तो आपको यह देखना चाहिए कि हमारा ऐप http: // localhost: 4200 / index.html में इंटरनेट के कनेक्शन के बिना काम कर रहा है।

लेकिन http: // localhost: 4200 में / हमें एक समस्या है और यह लोड नहीं करता है, यह स्थैतिक सामग्री कैश के कारण है जो केवल प्रकट में सूचीबद्ध फ़ाइलों का कार्य करता है।

उदाहरण के लिए, यदि मेनिफ़ेस्ट /index.html का URL घोषित करता है, तो /index.html के अनुरोधों को कैश द्वारा उत्तर दिया जाएगा, लेकिन / या कुछ / मार्ग का अनुरोध नेटवर्क पर जाएगा।

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

वर्तमान में, कॉन्फ़िगरेशन का यह खंड हाथ से लिखा जाना चाहिए (19-7-2017)। आखिरकार, यह एप्लिकेशन स्रोत में मौजूद मार्ग कॉन्फ़िगरेशन से उत्पन्न होगा।

इसलिए यदि अब हम प्रोजेक्ट के मूल में ngsw-घोषणापत्र बनाते हैं या बनाते हैं

{
  "routing": {
    "routes": {
      "/": {
        "prefix": false
      }
    },
    "index": "/index.html"
  }
}

और हम फिर से अपना ऐप बनाते हैं, अब जब हम http: // localhost: 4200 / पर जाते हैं , तो हमें http: // localhost: 4200 / index.html पर रीडायरेक्ट किया जाना चाहिए।

रूटिंग के बारे में अधिक जानकारी के लिए आधिकारिक दस्तावेज यहां पढ़ें

यहां आप सेवाकर्मियों के बारे में अधिक दस्तावेज पा सकते हैं:

https://developers.google.com/web/fundamentals/getting-started/primers/service-workers

https://docs.google.com/document/d/19S5ozevWighny788nI99worpcIMDnwWVmaJDGf_RoDY/edit#

और यहां आप SW प्रीचेज लाइब्रेरी का उपयोग करके काम करने वाली सेवा को लागू करने का एक वैकल्पिक तरीका देख सकते हैं:

https://coryrylan.com/blog/fast-offline-angular-apps-with-service-workers



Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow