अनुमान लगाने के नियमों का इस्तेमाल, अगले पेज के नेविगेशन को प्रीफ़ेच और प्रीरेंडर करने के लिए किया जा सकता है. इसके बारे में पिछली पोस्ट में बताया गया है. इसकी मदद से, पेज तेज़ी से या तुरंत लोड हो सकता है. साथ ही, इन अतिरिक्त पेज नेविगेशन के लिए, वेबसाइट की परफ़ॉर्मेंस की अहम जानकारी बेहतर हो जाती है.
अनुमान लगाने के नियमों को डीबग करना मुश्किल हो सकता है. खास तौर पर, यह पहले से रेंडर किए गए पेजों के लिए सही है, क्योंकि ये पेज एक अलग रेंडरर में रेंडर किए जाते हैं. यह एक ऐसे बैकग्राउंड टैब की तरह होता है जो चालू होने पर, मौजूदा टैब की जगह ले लेता है. इसलिए, DevTools के सामान्य विकल्पों का इस्तेमाल हमेशा समस्याओं को डीबग करने के लिए नहीं किया जा सकता.
Chrome टीम, अनुमान लगाने के नियमों को डीबग करने के लिए, DevTools से जुड़ी सहायता को बेहतर बनाने के लिए लगातार काम कर रही है. इस पोस्ट में, आपको पता चलेगा कि किसी पेज पर अनुमान लगाने से जुड़े नियमों को समझने के लिए, इन टूल का इस्तेमाल कैसे किया जा सकता है. साथ ही, यह भी बताया गया है कि ये तरीके काम क्यों नहीं करते हैं, और डेवलपर कब ज़्यादा DevTools इस्तेमाल कर सकते हैं. कब नहीं.
"pre-" की जानकारी शर्तें
"प्री-", बहुत से तो हम इनके बारे में विस्तार से जानकारी देने के साथ शुरुआत करेंगे:
- प्रीफ़ेच: आने वाले समय की परफ़ॉर्मेंस को बेहतर बनाने के लिए किसी संसाधन या दस्तावेज़ को पहले से फ़ेच करना. इस पोस्ट में, अनुमान लगाने के नियम एपीआई का इस्तेमाल करके प्रीफ़ेच करने के बारे में बताया गया है. हालांकि, यह इससे मिलते-जुलते नहीं है. हालांकि,
<link rel="prefetch">
के पुराने विकल्प का इस्तेमाल अक्सर सबरिसॉर्स को प्रीफ़ेच करने के लिए किया जाता है. - प्रीरेंडर: यह प्रीफ़ेच करने से कुछ कदम दूर है और असल में पूरे पेज को इस तरह रेंडर करता है, जैसे उपयोगकर्ता ने उस तक नेविगेट किया हो. हालांकि, अगर वह असल में पेज पर जाता है, तो इसे बैकग्राउंड रेंडर करने वाली ऐसी प्रोसेस में ही रखता है जो छिपी हुई होती है. यह दस्तावेज़,
<link rel="prerender">
के पुराने विकल्प (जो अब पूरी तरह से प्रीरेंडर नहीं होता) के बजाय, इस दस्तावेज़ के नए, अनुमान लगाने के नियम एपीआई वर्शन को लेकर परेशान है. - नेविगेशनल अनुमान: अनुमान लगाने के नियमों की वजह से ट्रिगर होने वाले नए प्रीफ़ेच और प्रीरेंडरिंग विकल्पों के लिए सामूहिक शब्द.
- पहले से लोड किया गया: यह ऐसा टर्म है जो कई टेक्नोलॉजी और प्रोसेस से जुड़ा होता है. जैसे,
<link rel="preload">
, प्रीलोड स्कैनर, और सर्विस वर्कर नेविगेशन प्रीलोड. इन आइटम के बारे में यहां नहीं बताया जाएगा. हालांकि, इस शर्त को शामिल किया गया है, ताकि इन्हें "नेविगेशन से जुड़े अनुमान" से साफ़ तौर पर अलग किया जा सके शब्द.
prefetch
के लिए अनुमान लगाने के नियम
अनुमान लगाने के नियमों का इस्तेमाल, अगले नेविगेशन के दस्तावेज़ को प्रीफ़ेच करने के लिए किया जा सकता है. उदाहरण के लिए, किसी पेज में यह JSON डालने पर, next.html
और next2.html
प्रीफ़ेच कर दिए जाएंगे:
<script type="speculationrules">
{
"prefetch": [
{
"source": "list",
"urls": ["next.html", "next2.html"]
}
]
}
</script>
पुराने <link rel="prefetch">
सिंटैक्स के मुकाबले, नेविगेशन प्रीफ़ेच के लिए अनुमान लगाने के नियमों के कुछ फ़ायदे होते हैं. जैसे, ज़्यादा बेहतर एपीआई और नतीजे एचटीटीपी डिस्क कैश के बजाय मेमोरी कैश में सेव होते हैं.
prefetch
अनुमान लगाने के नियमों को डीबग करें
अनुमान लगाने के नियमों से ट्रिगर होने वाले प्रीफ़ेच, नेटवर्क पैनल में दूसरे फ़ेच की तरह ही देखे जा सकते हैं:
![Chrome DevTools का नेटवर्क पैनल, जो प्रीफ़ेच किए गए दस्तावेज़ दिखा रहा है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/network-panel-chrome-devtools-prefetch.png?hl=hi)
लाल रंग से हाइलाइट किए गए दो अनुरोध, प्रीफ़ेच किए गए संसाधन हैं, जिन्हें टाइप कॉलम में देखा जा सकता है. इन्हें Lowest
प्राथमिकता पर फ़ेच किया जाता है, क्योंकि ये आने वाले समय में होने वाले नेविगेशन के लिए हैं. Chrome, मौजूदा पेज के संसाधनों को प्राथमिकता देता है.
इनमें से किसी एक पंक्ति पर क्लिक करने से, Sec-Purpose: prefetch
एचटीटीपी हेडर भी दिखता है. इससे सर्वर साइड पर इन अनुरोधों की पहचान की जा सकती है:
![Chrome DevTools प्रीफ़ेच हेडर, जिनमें सेक-मकसद को प्रीफ़ेच करने के लिए सेट किया गया है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/chrome-devtools-prefetch-sec-purpose-header.png?hl=hi)
अनुमान के हिसाब से लोड होने वाले टैब की मदद से, prefetch
को डीबग करें
Chrome DevTools के ऐप्लिकेशन पैनल में, बैकग्राउंड सेवाएं सेक्शन में अनुमान लोड करने का एक नया सेक्शन जोड़ा गया है. इससे अनुमान लगाने के नियमों को डीबग करने में मदद मिलेगी:
![Chrome DevTools के अनुमान के हिसाब से लोड होने वाले टैब, प्रीफ़ेच नियम दिखा रहे हैं](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/speculations-rules-tab-prefetch.png?hl=hi)
इस सेक्शन में तीन टैब उपलब्ध हैं:
- अनुमान लोड होने पर, जो मौजूदा पेज की प्रीरेंडरिंग की स्थिति के बारे में जानकारी देते हैं.
- ऐसे नियम जिनमें मौजूदा पेज पर मिले सभी नियमों के सेट की सूची होती है.
- ऐसे अनुमान जिनमें नियम के सेट में मौजूद, प्रीफ़ेच और पहले से रेंडर किए गए सभी यूआरएल की सूची होती है.
पिछले स्क्रीनशॉट में अनुमान टैब दिखाया गया है और हम देख सकते हैं कि इस उदाहरण पेज में तीन पेजों को प्रीफ़ेच करने के लिए, सिर्फ़ अनुमान लगाने के नियमों का एक सेट है. इनमें से दो प्रीफ़ेच हो गए और एक नहीं हो सका. नियम सेट के बगल में दिए गए आइकॉन पर क्लिक करके, आपको एलिमेंट पैनल में नियम सेट के सोर्स पर ले जाया जा सकता है. इसके अलावा, स्थिति लिंक पर क्लिक करके आपको उस नियम-सेट के लिए फ़िल्टर किए गए अनुमान टैब पर ले जाया जा सकता है.
अनुमान टैब में, टारगेट यूआरएल की सभी कार्रवाइयों की सूची होती है. साथ ही, उनमें हर अनुमान की स्थिति और कार्रवाई (प्रीफ़ेच या प्रीरेंडरिंग) की जानकारी भी होती है, जिसके नियम सेट का इस्तेमाल किया गया था (क्योंकि यह एक पेज पर एक से ज़्यादा हो सकती है). साथ ही, इसमें हर अनुमान की स्थिति भी शामिल होती है:
![Chrome DevTools के अनुमान लगाने वाला टैब, प्रीफ़ेच किए गए यूआरएल और उनकी स्थिति को दिखाता है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/speculations-prefetch-annotated.png?hl=hi)
यूआरएल के ऊपर, ड्रॉप-डाउन का इस्तेमाल करके सभी नियम सेट के यूआरएल दिखाए जा सकते हैं या सिर्फ़ किसी खास नियम सेट के यूआरएल दिखाए जा सकते हैं. उसके नीचे, सभी यूआरएल एक सूची में मौजूद होंगे. किसी यूआरएल पर क्लिक करने से आपको ज़्यादा जानकारी मिलती है.
इस स्क्रीनशॉट में, हम next3.html
पेज पर गड़बड़ी की वजह देख सकते हैं (जो मौजूद नहीं है. इसलिए, यह 404 दिखाता है, जो कि एक नॉन-2xx एचटीटीपी स्टेटस कोड है).
खास जानकारी टैब यानी अनुमान लोड होने पर, इस पेज के लिए अनुमान के हिसाब से यूआरएल लोड होने की स्थिति की रिपोर्ट दिखती है. इससे पता चलता है कि इस पेज के लिए प्रीफ़ेच या प्रीरेंडरिंग की सुविधा का इस्तेमाल किया गया था या नहीं.
प्रीफ़ेच किए गए किसी पेज के लिए, जब उस पेज को इस पर नेविगेट किया जाएगा, तो आपको एक सफल मैसेज दिखेगा:
![Chrome DevTools के अनुमान के हिसाब से लोड होने वाला टैब, जो प्रीफ़ेच दिखा रहा है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/successful-prefetch.png?hl=hi)
मेल न खाने वाले अनुमान
जब अनुमान के नियमों वाले किसी ऐसे पेज से नेविगेशन किया जाता है जिसकी वजह से प्रीफ़ेच या प्रीरेंडरिंग की सुविधा का इस्तेमाल नहीं किया जाता, तो टैब का एक अतिरिक्त सेक्शन इस बारे में ज़्यादा जानकारी दिखाएगा कि यूआरएल, अनुमान लगाने वाले किसी भी यूआरएल से मेल क्यों नहीं खाता. इससे आपको अनुमान लगाने से जुड़े नियमों में टाइपिंग की गलतियों को पहचानने में मदद मिलती है.
![Chrome DevTools के अनुमान के हिसाब से लोड होने वाले पेज का टैब, जिसमें दिखाया गया है कि मौजूदा यूआरएल किस तरह पिछले पेज के अनुमान लगाने के नियमों में मौजूद किसी भी यूआरएल से मैच नहीं करता](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/unsuccessful-prefetch.png?hl=hi)
उदाहरण के लिए, हमने next4.html
पर नेविगेट किया, लेकिन सिर्फ़ next.html
, next2.html
या next3.html
ही प्रीफ़ेच हैं. इसलिए, हम देख सकते हैं कि यह उन तीनों नियमों में से किसी भी नियम से पूरी तरह मेल नहीं खाता.
अनुमान लोड टैब, अनुमान लगाने के नियमों को खुद डीबग करने और JSON में सिंटैक्स की गड़बड़ियों को खोजने में बहुत मदद करते हैं.
प्रीफ़ेच के मामले में, ऐसा हो सकता है कि नेटवर्क पैनल जाना-पहचाना हो. प्रीफ़ेच नहीं होने के उदाहरण के लिए, आप यहां प्रीफ़ेच के लिए 404 देख सकते हैं:
![Chrome DevTools नेटवर्क पैनल, जो प्रीफ़ेच नहीं कर सका](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/chrome-devtools-network-failed-prefetch.png?hl=hi)
हालांकि, अनुमान लोड टैब, प्रीरेंडरिंग अनुमान लगाने के नियमों के लिए ज़्यादा काम के होते हैं. इन नियमों के बारे में आगे बताया गया है.
prerender
के लिए अनुमान लगाने के नियम
प्रीरेंडरिंग अनुमान के नियम, उसी सिंटैक्स का पालन करते हैं जिसका इस्तेमाल प्रीफ़ेच अनुमान लगाने के नियम करते हैं. उदाहरण के लिए:
<script type="speculationrules">
{
"prerender": [
{
"source": "list",
"urls": ["next.html", "next2.html"]
}
]
}
</script>
यह नियम सेट, तय किए गए पेजों का पूरा लोड और रेंडर होना ट्रिगर करता है (कुछ खास पाबंदियों के आधार पर). इससे, कॉन्टेंट तुरंत लोड होने की सुविधा मिलती है. हालांकि, इसके लिए आपको ज़्यादा संसाधनों की ज़रूरत पड़ती है.
हालांकि, प्रीफ़ेच के उलट ये नेटवर्क पैनल में देखने के लिए उपलब्ध नहीं होते, क्योंकि इन्हें Chrome में एक अलग रेंडरिंग प्रोसेस में फ़ेच और रेंडर किया जाता है. यह पहले से रेंडर किए जाने वाले अनुमान के नियमों को डीबग करने के लिए, अनुमान लोड टैब को ज़्यादा ज़रूरी बना देता है.
अनुमान के हिसाब से लोड होने वाले टैब की मदद से, prerender
को डीबग करें
इन अप्रत्यक्ष लोड स्क्रीन का इस्तेमाल, पहले से रेंडर किए जाने के अनुमान के नियमों के लिए किया जा सकता है. यह उसी तरह का डेमो पेज होता है जो तीन पेजों को प्रीफ़ेच करने के बजाय, प्रीरेंडर करने की कोशिश करता है:
![Chrome DevTools, अनुमान के हिसाब से ढल जाने वाले टूल, ऐसे पेज के लिए टैब लोड करते हैं जिसमें पहले से अनुमान लगाने के नियम मौजूद होते हैं](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/speculations-rules-tab-prerender.png?hl=hi)
यहां हमें फिर से पता चला है कि तीन में से एक यूआरएल को पहले से रेंडर नहीं किया जा सका. डेवलपर, अनुमान टैब में हर यूआरएल के बारे में जानकारी हासिल कर सकते हैं. इसके लिए, उन्हें 2 के लिए तैयार, 1 काम नहीं करने वाले लिंक पर क्लिक करना होगा.
Chrome 121 में, हमने दस्तावेज़ के नियमों से जुड़ी सहायता की सुविधा लॉन्च की है. इससे ब्राउज़र, यूआरएल के खास सेट की सूची के बजाय, पेज पर मौजूद ऑरिजिन लिंक से ही इन लिंक को चुन सकता है:
<script type="speculationrules">
{
"prerender": [
{
"source": "document",
"where": {
"and": [
{"href_matches": "/*"},
{"not": { "href_matches": "/not-safe-to-prerender/*"}}
]
},
"eagerness": "moderate"
}
]
}
</script>
इस उदाहरण में, ऑरिजिन लिंक के सभी मिलते-जुलते लिंक चुने जाते हैं. हालांकि, इनमें पहले से रेंडर किए गए लिंक के तौर पर, /not-safe-to-prerender
से शुरू होने वाले लिंक शामिल नहीं होते.
यह प्रीरेंडरिंग eagerness
को moderate
पर भी सेट कर देता है. इसका मतलब है कि लिंक पर कर्सर घुमाने या उस पर क्लिक करने पर, नेविगेशन पहले से रेंडर हो जाता है.
अनुमान पर आधारित नियमों वाली डेमो साइट पर भी इसी तरह के नियम हैं. इस साइट के नए अनुमान लोड सेक्शन का इस्तेमाल करने से पता चलता है कि यह नया टैब, ज़रूरी शर्तें पूरी करता है. इसकी वजह यह है कि पेज पर ब्राउज़र को मिलने वाले सभी ज़रूरी शर्तें पूरी करने वाले यूआरएल सूची में शामिल हैं:
![Chrome DevTools के अनुमान लगाने वाला टैब, जिसमें ट्रिगर नहीं किए गए यूआरएल की संख्या मौजूद है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/document-rules-not-triggered.png?hl=hi)
स्टेटस ट्रिगर नहीं हुआ, क्योंकि इनके लिए प्रीरेंडरिंग की प्रोसेस शुरू नहीं हुई है. हालांकि, जब हम पॉइंटर को लिंक पर दबाकर रखते हैं, तब हमें हर यूआरएल को पहले से रेंडर किए जाने की वजह से, स्टेटस में बदलाव दिखता है:
![प्रीरेंडर किए गए पेजों के साथ Chrome DevTools के अनुमान लगाने वाला टैब, जो पहले ट्रिगर किए गए पेजों के साथ ट्रिगर हुआ है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/document-rules-triggered.png?hl=hi)
Chrome ने प्रीरेंडरिंग की सीमाएं तय की हैं, जिनमें moderate
की उत्सुकता के लिए, ज़्यादा से ज़्यादा दो प्रीरेंडरिंग शामिल हैं. इसलिए, तीसरे लिंक पर कर्सर घुमाने के बाद, हमें उस यूआरएल के काम न करने की वजह दिखती है:
![Chrome DevTools के अनुमान का टैब, जिस पर पहले से लोड नहीं किए जा सके उसकी जानकारी दिख रही है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/replaced-prerender-shows-as-failure.png?hl=hi)
अन्य DevTools पैनल की मदद से prerender
को डीबग करें
प्रीफ़ेच किए गए पेजों के उलट, जो पेज पहले से रेंडर किए गए हैं वे नेटवर्क पैनल जैसे DevTools पैनल की मौजूदा रेंडरिंग प्रोसेस में नहीं दिखेंगे. इसकी वजह यह है कि ये पेज, पर्दे के पीछे की गतिविधियों वाले रेंडरर में खुद ही रेंडर किए जाते हैं.
हालांकि, अब DevTools पैनल में इस्तेमाल किए गए रेंडरर को, सबसे ऊपर दाईं ओर मौजूद ड्रॉप-डाउन मेन्यू के ज़रिए या पैनल के सबसे ऊपर वाले हिस्से में यूआरएल चुनकर जांच करें चुनकर स्विच किया जा सकता है:
![Chrome DevTools से अब रेंडरर की जानकारी बदली जा सकती है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/switch-renderers.png?hl=hi)
यह ड्रॉप डाउन (और चुना गया मान) अन्य सभी पैनल पर भी शेयर किया जाता है, जैसे कि नेटवर्क पैनल, जहां आप यह देख सकते हैं कि अनुरोध किया जा रहा पेज पहले से रेंडर किया गया पेज है:
![Chrome DevTools नेटवर्क पैनल, जो पहले से रेंडर किए गए पेज के लिए नेटवर्क के अनुरोध दिखा रहा है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/network-with-different-renderer.png?hl=hi)
इन रिसॉर्स के एचटीटीपी हेडर देखकर हम पता लगा सकते हैं कि वे Sec-Purpose: prefetch;prerender
हेडर के साथ सेट अप हो जाएंगे:
![Chrome DevTools नेटवर्क पैनल, जो पहले से रेंडर किए गए पेज के लिए, सेक-पर्पस हेडर दिखा रहा है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/sec-purpose-headers-prerender.png?hl=hi)
इसके अलावा, एलिमेंट पैनल में पेज का कॉन्टेंट भी देखा जा सकता है. जैसा कि इस स्क्रीनशॉट में दिखाया गया है, जहां हमें दिखता है कि पहले से रेंडर किए गए पेज के लिए <h1>
एलिमेंट मौजूद है:
![पहले से रेंडर किए गए पेज के लिए, Chrome DevTools के एलिमेंट पैनल](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/prerender-elements-panel.png?hl=hi)
इसके अलावा, कंसोल पैनल में जाकर, पहले से रेंडर किए गए पेज से मिले कंसोल लॉग देखे जा सकते हैं:
![Chrome DevTools कंसोल पैनल, जो पहले से रेंडर किए गए पेज से कंसोल का आउटपुट दिखा रहा है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/prerender-console-panel.png?hl=hi)
पहले से रेंडर किए गए पेज पर, अनुमान लगाने के नियमों को डीबग करना
पिछले सेक्शन में, पेज पर पहले से रेंडर किए गए पेजों को डीबग करने के तरीके के बारे में बताया गया है, जिसकी वजह से पेज प्रीरेंडरिंग शुरू हो जाती है. हालांकि, पहले से रेंडर किए गए पेजों के लिए, आंकड़ों के कॉल करके या कंसोल में लॉग इन करके, डीबग करने की जानकारी भी दी जा सकती है. इसे पिछले सेक्शन में देखा जा सकता है.
इसके अलावा, जब उपयोगकर्ता पहले से रेंडर किए गए किसी पेज पर जाता है और उस पर नेविगेट करता है, तो अनुमान लोड टैब में यह स्थिति दिखती है. साथ ही, पेज को यह भी दिखेगा कि पेज को प्रीरेंडर कर दिया गया है या नहीं. अगर पेज को पहले से रेंडर नहीं किया जा सका, तो इस बारे में जानकारी दी जाएगी कि इस मामले में ऐसा क्यों किया गया है:
![Chrome DevTools के अनुमान के हिसाब से लोड होने वाले पेज का टैब, जो पहले से रेंडर किए गए पेज को सही तरीके से दिखाता है और न ही पूरा कर लेता है](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/success-failed-prerender.png?hl=hi)
इसके अलावा—जैसा कि प्रीफ़ेच के मामले में होता है—यह अनुमान लगाने के नियमों वाले ऐसे पेज से नेविगेट करने पर, जो मौजूदा पेज से मेल नहीं खाता, आपको यह दिखाने की कोशिश करेगा कि यूआरएल, अनुमान लोड टैब में पिछले पेज के अनुमान के नियमों में शामिल किए गए यूआरएल से मेल क्यों नहीं खाते:
![Chrome DevTools के अनुमान के हिसाब से लोड होने वाले पेज पर, मौजूदा यूआरएल और पिछले पेज के यूआरएल से मेल न खाने वाले यूआरएल दिखते हैं](https://developer.chrome.com/static/docs/devtools/application/debugging-speculation-rules/image/unsuccessful-prerender.png?hl=hi)
नतीजा
इस पोस्ट में, हमने ऐसे कई तरीकों के बारे में बताया है जिनसे डेवलपर, प्रीफ़ेच और पहले से रेंडर किए जाने वाले अनुमान के नियमों को डीबग कर सकते हैं. हमारी टीम, अनुमान लगाने से जुड़े नियमों को बनाने के लिए लगातार काम कर रही है. हमें डेवलपर से सुझाव चाहिए कि ऐसे और कौनसे तरीके अपनाकर इस नए एपीआई को डीबग करने में मदद मिल सकती है. हम डेवलपर को सलाह देते हैं कि वे Chrome से जुड़ी समस्या को ट्रैक करने वाले टूल पर जाकर, किसी सुविधा के अनुरोध या किसी गड़बड़ी के बारे में बताएं.
स्वीकार की गई
Unस्प्लैश पर नबेलसन फ़र्नांडीस की थंबाइल इमेज.