एचटीएमएल 5 में कैश मेनिफेस्ट: Difference between revisions
(Created page with "{{About|obsolete technology for making web pages accessible offline|regular HTTP cache|Web cache|modern technology for creating offline apps|Progressive web application}}{{Sho...") |
No edit summary |
||
Line 1: | Line 1: | ||
{{About| | {{About|वेब पेजों को ऑफ़लाइन पहुंच योग्य बनाने की अप्रचलित तकनीक|नियमित HTTP कैश|वेब कैश|ऑफ़लाइन ऐप्स बनाने की आधुनिक तकनीक|प्रगतिशील वेब अनुप्रयोग}}{{Short description|Local cache in a web file}} | ||
{{Copied to Wikibooks}} | {{Copied to Wikibooks}} | ||
{{Infobox file format | {{Infobox file format |
Revision as of 22:53, 19 July 2023
Filename extension |
.appcache |
---|---|
Internet media type |
text/cache-manifest |
Developed by | World Wide Web Consortium |
Standard | HTML5 |
Open format? | Yes |
Website | html |
HTML5 में कैश मेनिफेस्ट एक सॉफ्टवेयर स्टोरेज सुविधा थी जो नेटवर्क कनेक्शन के बिना भी वेब अनुप्रयोग तक पहुंचने की क्षमता प्रदान करती थी। यह 28 अक्टूबर 2014 को W3C अनुशंसा का हिस्सा बन गया।[1] 2021 से, यह तकनीक अब व्यापक रूप से उपलब्ध नहीं है। इसे फ़ायरफ़ॉक्स 85 से हटा दिया गया था,[2] और Chrome 84 में डिफ़ॉल्ट रूप से अक्षम किया गया और Chrome 95 में हटा दिया गया।[3] इस समय किसी भी ऑफ़लाइन वेब एप्लिकेशन सुविधाओं का उपयोग करने की अत्यधिक अनुशंसा नहीं की जाती है और इसके बजाय Progressive_Web_Apps#Service_workers का उपयोग करने की अनुशंसा की जाती है।[4] कैश मैनिफ़ेस्ट वेब एप्लिकेशन मेनिफेस्ट से भिन्न होते हैं, एक JSON-आधारित फ़ाइल स्वरूप जो प्रगतिशील वेब ऐप तकनीक का हिस्सा है, और as of 2023[update] वर्तमान में सक्रिय है और W3C में मानकीकरण प्रक्रिया से गुजर रहा है।[5]
पृष्ठभूमि
वेब एप्लिकेशन में वे वेब पेज शामिल होते हैं जिन्हें नेटवर्क से डाउनलोड करने की आवश्यकता होती है। ऐसा होने के लिए नेटवर्क कनेक्शन होना चाहिए. हालाँकि, ऐसे कई उदाहरण हैं जब उपयोगकर्ता अपने नियंत्रण से परे परिस्थितियों के कारण नेटवर्क से कनेक्ट नहीं हो पाते हैं। [[HTML5]] वेब कैश मेनिफेस्ट का उपयोग करके नेटवर्क कनेक्शन के बिना भी वेब एप्लिकेशन तक पहुंचने की क्षमता प्रदान करता है।
वेब एप्लिकेशन में यूनिफ़ॉर्म रिसोर्स लोकेटर द्वारा पहचाने गए संसाधन शामिल होते हैं। ये HTML, व्यापक शैली पत्रक , जावास्क्रिप्ट, छवियां या कोई अन्य स्रोत हो सकते हैं जो वेब एप्लिकेशन को प्रस्तुत करने के लिए आवश्यक हैं। उनके पते को एक प्रकट फ़ाइल में कॉपी किया जा सकता है, जिसे वेब एप्लिकेशन के लेखक द्वारा नियमित रूप से अपडेट किया जा सकता है, जो जोड़े या हटाए गए किसी भी नए वेब पते को इंगित करता है। पहली बार किसी नेटवर्क से कनेक्ट होने पर, एक वेब ब्राउज़र HTML5 मेनिफेस्ट फ़ाइल को पढ़ेगा, दिए गए संसाधनों को डाउनलोड करेगा और उन्हें स्थानीय रूप से संग्रहीत करेगा। फिर, नेटवर्क कनेक्शन की अनुपस्थिति में, वेब ब्राउज़र स्थानीय प्रतियों पर स्थानांतरित हो जाएगा और वेब एप्लिकेशन को ऑफ़लाइन प्रस्तुत करेगा।
मूल बातें
ऑफ़लाइन एप्लिकेशन को काम करने के लिए, वेब डेवलपर द्वारा एक कैश मेनिफेस्ट फ़ाइल बनाई जानी चाहिए। यदि वेब एप्लिकेशन एक से अधिक पेज से अधिक है तो प्रत्येक पेज में एक मेनिफेस्ट विशेषता होनी चाहिए जो कैश मेनिफेस्ट को इंगित करती है। मेनिफेस्ट को संदर्भित करने वाला प्रत्येक पृष्ठ स्थानीय रूप से संग्रहीत किया जाएगा।[6] कैश मेनिफेस्ट फ़ाइल सर्वर के दूसरे भाग में स्थित एक टेक्स्ट फ़ाइल है। इसे सामग्री प्रकार के साथ प्रस्तुत किया जाना चाहिए text/cache-manifest
[7]
विशेषता manifest="<path>"
कैश मेनिफेस्ट फ़ाइल को काम करने के लिए html तत्व में जोड़ा जाना चाहिए।[7]उदाहरण:
<!DOCTYPE HTML>
<html manifest="cache.appcache">
<body>
…
</body>
</html>
मेनिफेस्ट विशेषता का तर्क मेनिफेस्ट फ़ाइल का एक सापेक्ष या निरपेक्ष पथ है।
नीचे दी गई HTML फ़ाइल पर विचार करें. <html> तत्व इंगित करता है कि कैश.एपकैश नामक फ़ाइल में इस वेब पेज के ऑफ़लाइन काम करने के लिए आवश्यक संसाधनों (जैसे, test.js, test.css) की सूची होगी। इस फ़ाइल के सामान्य नाम कैश.मैनिफ़ेस्ट और मेनिफेस्ट.एपकैश हैं।
<!—- test.html -->
<!DOCTYPE HTML>
<html manifest="cache.appcache">
<head>
<title>Test</title>
<script src="test.js"></script>
<link rel="stylesheet" href="test.css">
</head>
<body>
Testing the manifest file.
</body>
</html>
सिंटेक्स
मेनिफेस्ट फ़ाइल लाइन से शुरू होनी चाहिए CACHE MANIFEST
. टिप्पणियाँ a से प्रारंभ होती हैं #
, रिक्त स्थान और रिक्त पंक्तियों को नजरअंदाज कर दिया जाता है।[8]
नीचे कैश मेनिफेस्ट फ़ाइल का एक उदाहरण दिया गया है।
उदाहरण 1:
कैश मैनिफेस्ट /test.css /test.js /test.png
This manifest file lists three resources: a CSS file, a JavaScript file and a PNG image. When the above file is loaded, the browser will download the test.css, test.js and test.png वेब सर्वर में रूट डायरेक्टरी से फ़ाइलें।[7]परिणामस्वरूप, जब भी किसी का नेटवर्क कनेक्ट नहीं होगा, तो संसाधन उन्हें ऑफ़लाइन उपलब्ध होंगे।
जैसा कि नीचे दिखाया गया है, कैश मेनिफेस्ट सापेक्ष पथ या यहां तक कि पूर्ण यूआरएल का भी उपयोग कर सकते हैं।[8][9][10] उदाहरण 2:
कैश मैनिफेस्ट /main/features.js /main/settings/index.css <nowiki>http://files/images/scene.jpg</नोविकी> <nowiki>http://files/images/world.jpg</नोविकी>
फ़ाइल हेडर
कैश मेनिफेस्ट फ़ाइल में तीन अनुभाग शीर्षलेख होते हैं।[7]
- CACHE हेडर के साथ स्पष्ट अनुभाग.
- नेटवर्क हेडर के साथ ऑनलाइन श्वेतसूची अनुभाग।
- फ़ॉलबैक हेडर फ़ॉलबैक के साथ फ़ॉलबैक अनुभाग।
नोट: उपरोक्त उदाहरण 1 और उदाहरण 2, किसी भी अनुभाग शीर्षलेख को इंगित नहीं करते हैं और इसलिए उन्हें डिफ़ॉल्ट रूप से एक स्पष्ट अनुभाग माना जाता है।
हेडर नेटवर्क के साथ ऑनलाइन श्वेतसूची अनुभाग
उदाहरण 3:
कैश मैनिफेस्ट नेटवर्क: /checking.cgi कैश: /test.css /test.js /test.png
इस उदाहरण में हेडर शामिल हैं. लाइन, नेटवर्क: ऑनलाइन श्वेतसूची अनुभाग की शुरुआत है। इस अनुभाग के अंतर्गत सूचीबद्ध संसाधन कभी भी कैश्ड नहीं होते हैं और ऑफ़लाइन उपलब्ध नहीं होते हैं।[7]परिणामस्वरूप, जब संसाधन को ऑफ़लाइन लोड करने का प्रयास किया जाएगा तो एक त्रुटि उत्पन्न होगी।
हेडर कैश द्वारा स्पष्ट अनुभाग में बदलाव किया गया है: और संसाधनों (सीएसएस स्टाइलशीट, जावास्क्रिप्ट और छवि फ़ाइल) को ऑफ़लाइन डाउनलोड और उपयोग किया जा सकता है।
हेडर FALLBACK के साथ फ़ॉलबैक अनुभाग
कैश मैनिफ़ेस्ट फ़ाइल में फ़ॉलबैक अनुभाग का उपयोग उन ऑनलाइन संसाधनों को प्रतिस्थापित करने के लिए किया जा सकता है जिन्हें कैश नहीं किया जा सकता है या सफलतापूर्वक कैश नहीं किया गया है।[7]
उदाहरण 4:
कैश मैनिफेस्ट मैदान छोड़ना: / /ऑफ़लाइन.html नेटवर्क: …
उदाहरण 4 में, फ़ॉलबैक अनुभाग में एक पंक्ति होती है। यानी, / /ऑफ़लाइन.html। 'ऑफ़लाइन' से पहले एकल वर्ण (/) किसी की साइट पर किसी भी यूआरएल पैटर्न से मेल खाएगा।[7]यदि ब्राउज़र को ऐप कैश में पेज नहीं मिलता है, तो एप्लिकेशन /ऑफ़लाइन.html पेज प्रदर्शित करेगा।
घटना प्रवाह
घटनाएँ के अंतर्गत हैं ApplicationCache
जावास्क्रिप्ट ऑब्जेक्ट.
यदि ब्राउज़र किसी वेब पेज पर जाता है, पहले वेब पेज नहीं देखा है और परिणामस्वरूप मेनिफेस्ट फ़ाइल को नहीं पहचानता है, तो निम्नलिखित घटनाएं घटित होंगी।[8]
Checking
घटना - तब होती है जब ब्राउज़र किसी वेब पेज पर जाता है और <html> तत्व पर मेनिफेस्ट विशेषता पढ़ता है।Downloading
इवेंट - यह मेनिफेस्ट फ़ाइल में दिए गए सभी संसाधनों को डाउनलोड करेगा।Progress
इवेंट - इसमें यह जानकारी होती है कि कितनी फ़ाइलें डाउनलोड की गई हैं और कितनी फ़ाइलें डाउनलोड की जानी बाकी हैं।Cached
घटना - तब घटित होती है जब सभी फ़ाइलें डाउनलोड हो जाती हैं और ऑफ़लाइन वेब एप्लिकेशन ऑफ़लाइन उपयोग के लिए सुसज्जित हो जाता है।
यदि ब्राउज़र पहले वेब पेज पर गया है और मेनिफेस्ट फ़ाइल को पहचानता है तो निम्नलिखित घटनाएं घटित होंगी।[8]
* Noupdate
घटना - यह तब घटित होगा जब कैश मेनिफ़ेस्ट नहीं बदला गया हो।
Downloading
घटना - यदि कैश मेनिफेस्ट ने संसाधनों को बदल दिया है तो फ़ाइलें फिर से डाउनलोड की जाएंगी।Progress
इवेंट - इसमें यह जानकारी होती है कि कितनी फ़ाइलें डाउनलोड हो चुकी हैं और कितनी फ़ाइलें डाउनलोड होनी बाकी हैं।Updateready
इवेंट - पुनः डाउनलोडिंग पूरी होने के बाद, यह इवेंट ट्रिगर हो जाता है, जो दर्शाता है कि नया ऑफ़लाइन संस्करण उपयोग के लिए तैयार है।
यदि उपरोक्त घटनाओं में किसी भी समय कोई त्रुटि होती है, तो ब्राउज़र एक त्रुटि घटना को ट्रिगर करेगा और प्रक्रिया को रोक देगा। नीचे कुछ त्रुटियाँ दी गई हैं जो संसाधनों को दोबारा डाउनलोड करते समय हो सकती हैं।[9]
- पृष्ठ नहीं मिला (HTTP 404) या पृष्ठ स्थायी रूप से चला गया (HTTP त्रुटि 410)।
- मैनिफ़ेस्ट की ओर इंगित करने वाले HTML पृष्ठ को डाउनलोड करने में विफलता।[7]* अद्यतन होने के दौरान कैश मेनिफ़ेस्ट बदल गया।[7]* कैश मेनिफ़ेस्ट बदल दिया गया था लेकिन ब्राउज़र ने मेनिफ़ेस्ट में कोई संसाधन डाउनलोड नहीं किया।[7]
यह भी देखें
- एचटीएमएल5
- ऑफ़लाइन पाठक
- वेब कैश
संदर्भ
- ↑ "Application cache as part of the W3C Recommendation". 28 October 2014. Retrieved 30 May 2016.
- ↑ "Using the application cache - HTML: HyperText Markup Language | MDN". developer.mozilla.org. Archived from the original on 2019-02-15. Retrieved 2021-04-11.
- ↑ "AppCache हटाने की तैयारी की जा रही है". web.dev (in English). Archived from the original on 2020-05-20. Retrieved 2021-09-02.
- ↑ "विंडो.एप्लिकेशन कैश". MDN Web Docs. Mozilla. Retrieved 2020-12-29.
- ↑ "वेब एप्लिकेशन मेनिफेस्ट". www.w3.org. Retrieved 2023-04-09.
- ↑ Bidelman, Eric (29 October 2013). "एप्लिकेशन कैश का उपयोग करने के लिए एक शुरुआती मार्गदर्शिका". Retrieved 23 April 2014.
- ↑ 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 Pilgrim, Mark (2010). HTML5 Up and Running. O'Reilley. Archived from the original on 2011-10-03. Retrieved 2018-11-16.
- ↑ 8.0 8.1 8.2 8.3 "W3 HTML5 Manifests". HTML5. Archived from the original on 24 December 2010. Retrieved 3 April 2011.
- ↑ 9.0 9.1 "देव.ओपेरा". HTML5. Retrieved 3 April 2011.
- ↑ "क्या?". HTML5. Archived from the original on 14 April 2011. Retrieved 3 April 2011.