Chrome DevTools की मदद से अनुमान लगाने के नियमों को डीबग करना

अनुमान लगाने के नियमों का इस्तेमाल, अगले पेज नेविगेशन को प्रीफ़ेच और प्रीरेंडर करने के लिए किया जा सकता है. इसके बारे में पिछली पोस्ट में बताया गया है. इससे पेज तेज़ी से या तुरंत लोड हो जाते हैं, जिससे वेबसाइट की परफ़ॉर्मेंस की अहम जानकारी, इन अन्य पेज नेविगेशन के लिए बेहतर हो जाती है.

अनुमान लगाने के नियमों को डीबग करना मुश्किल हो सकता है. पहले से रेंडर किए गए पेजों के लिए ऐसा खास तौर पर सही होता है, क्योंकि ये पेज एक अलग रेंडरर में रेंडर किए जाते हैं. यह किसी छिपे हुए बैकग्राउंड टैब की तरह होता है, जो चालू होने पर मौजूदा टैब की जगह ले लेता है. इसलिए, समस्याओं को डीबग करने के लिए, DevTools के सामान्य विकल्पों का इस्तेमाल हमेशा नहीं किया जा सकता.

Chrome टीम, अनुमान लगाने के नियमों को डीबग करने के लिए, DevTools की सुविधा को बेहतर बनाने के लिए लगातार काम कर रही है. इस पोस्ट में, आपको इन टूल को इस्तेमाल करने के अलग-अलग तरीके मिलेंगे. इनकी मदद से, यह समझा जा सकता है कि किसी पेज पर अनुमान लगाने से जुड़े नियम क्यों काम करते हैं और डेवलपर आम तौर पर उपलब्ध DevTools विकल्पों का इस्तेमाल कब कर सकते हैं और कब नहीं.

"पूर्व" शब्दों के बारे में जानकारी

"प्री-" बहुत सारे शब्दों को समझना मुश्किल है. इसलिए, हम आपको इन बातों से शुरुआत करेंगे:

  • प्रीफ़ेच: परफ़ॉर्मेंस को बेहतर बनाने के लिए, संसाधन या दस्तावेज़ को पहले से फ़ेच किया जा सकता है. इस पोस्ट में, अनुमान के नियम वाले एपीआई का इस्तेमाल करके, उन दस्तावेज़ों को प्रीफ़ेच किया गया है जो अनुमान लगाने के नियम वाले एपीआई का इस्तेमाल करते हैं. इसमें, इससे मिलते-जुलते, लेकिन पुराने <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 के नेटवर्क पैनल में, प्रीफ़ेच किए गए दस्तावेज़ दिख रहे हैं
Chrome DevTools के नेटवर्क पैनल में, प्रीफ़ेच किए गए दस्तावेज़ दिख रहे हैं

लाल रंग में हाइलाइट किए गए दो अनुरोध, प्रीफ़ेच किए गए संसाधन होते हैं. इन्हें टाइप कॉलम में देखा जा सकता है. इन्हें Lowest की प्राथमिकता पर फ़ेच किया जाता है, क्योंकि ये आने वाले नेविगेशन के लिए होती हैं. साथ ही, Chrome मौजूदा पेज के संसाधनों को प्राथमिकता देता है.

किसी भी एक लाइन पर क्लिक करने पर, Sec-Purpose: prefetch एचटीटीपी हेडर भी दिखता है. इस तरह से सर्वर साइड पर इन अनुरोधों की पहचान की जा सकती है:

Chrome DevTools के प्रीफ़ेच हेडर, जिनके सेक्शन का मकसद प्रीफ़ेच पर सेट किया गया है
Chrome DevTools के प्रीफ़ेच हेडर, जिनके Sec-मकसद को प्रीफ़ेच पर सेट किया गया है

अनुमान के हिसाब से यूआरएल लोड होने की सुविधा वाले टैब की मदद से, prefetch को डीबग करें

अनुमान लगाने के नियमों को डीबग करने में मदद के लिए, बैकग्राउंड सेवाएं सेक्शन में, Chrome DevTools के ऐप्लिकेशन पैनल में नया अनुमान के हिसाब से लोड होना सेक्शन जोड़ा गया है:

Chrome DevTools के अनुमान के हिसाब से लोड होने वाले टैब, प्रीफ़ेच का नियम दिखा रहे हैं
Chrome DevTools के अनुमान पर आधारित टैब, जिनमें प्रीफ़ेच के नियम दिखाए गए हैं

इस सेक्शन में तीन टैब उपलब्ध हैं:

  • अनुमानित लोड, जिसमें मौजूदा पेज की पहले से रेंडर की गई स्थिति की सूची होती है.
  • नियम, जिसमें मौजूदा पेज पर मिले सभी नियम सेट की सूची होती है.
  • अनुमान, जिनमें नियमों के सेट में मौजूद प्रीफ़ेच और पहले से रेंडर किए गए सभी यूआरएल की सूची होती है.

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

अनुमान टैब में, सभी टारगेट यूआरएल के साथ-साथ वह कार्रवाई (फ़ेच या प्रीरेंडरिंग) होती है जिससे वे आए थे, नियम के सेट के साथ (जैसे कि पेज पर एक से ज़्यादा हो सकते हैं), और हर अनुमान की स्थिति शामिल होती है:

Chrome DevTools के अनुमान टैब, प्रीफ़ेच किए गए यूआरएल के साथ उनकी स्थिति दिखा रहा है
Chrome DevTools अनुमान टैब, प्रीफ़ेच किए गए यूआरएल के साथ उनकी स्थिति दिखाता है

यूआरएल के ऊपर, ड्रॉप-डाउन का इस्तेमाल करके सभी नियम सेट के यूआरएल या सिर्फ़ किसी खास नियम सेट के यूआरएल दिखाए जा सकते हैं. उसके नीचे, सभी यूआरएल की सूची होती है. यूआरएल पर क्लिक करने से आपको ज़्यादा जानकारी मिलती है.

इस स्क्रीनशॉट में, हम next3.html पेज (जो मौजूद नहीं है और इसलिए 404 दिखाता है, जो कि एक गैर-2xx एचटीटीपी स्टेटस कोड है) के सफल न होने की वजह देख सकते हैं.

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

प्रीफ़ेच किए गए पेज के लिए, उस पेज को यहां नेविगेट करने पर आपको एक सफल मैसेज दिखेगा:

Chrome DevTools &#39;अनुमान के मुताबिक लोड&#39; टैब में प्रीफ़ेच दिखाया गया है
Chrome DevTools का अनुमान के हिसाब से लोड होने वाला टैब, जो प्रीफ़ेच दिखा रहा है

मेल न खाने वाले अनुमान

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

Chrome DevTools &#39;अनुमान के मुताबिक लोड&#39; टैब. इसमें दिखाया गया है कि किस तरह मौजूदा यूआरएल, पिछले पेज पर अनुमान लगाने के लिए बने नियमों में मौजूद किसी भी यूआरएल से मेल नहीं खाता
मेल न खाने वाले यूआरएल को DevTools में हाइलाइट किया गया है

उदाहरण के लिए, यहां हमने next4.html पर नेविगेट किया है, लेकिन सिर्फ़ next.html, next2.html या next3.html ही प्रीफ़ेच हैं, इसलिए हम देख सकते हैं कि यह उन तीन नियमों में से किसी भी नियम से पूरी तरह मेल नहीं खाता है.

अनुमानित लोड टैब, अनुमान के नियमों को खुद डीबग करने और JSON में सिंटैक्स की गड़बड़ियों को ढूंढने में काफ़ी मदद करते हैं.

प्रीफ़ेच की तरह, नेटवर्क पैनल ज़्यादा जाना-पहचाना जगह हो सकता है. प्रीफ़ेच न हो पाने के उदाहरण के लिए, आप यहां प्रीफ़ेच के लिए 404 देख सकते हैं:

Chrome DevTools नेटवर्क पैनल, जिसमें प्रीफ़ेच नहीं किया जा सका
Chrome DevTools नेटवर्क पैनल, जिसमें प्रीफ़ेच नहीं किया जा सका

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

prerender के लिए अनुमान लगाने के नियम

प्रीरेंडरिंग अनुमान के नियम, प्रीफ़ेच किए जाने वाले अनुमान के नियमों जैसा ही सिंटैक्स इस्तेमाल करते हैं. उदाहरण के लिए:

<script type="speculationrules">
  {
    "prerender": [
      {
        "source": "list",
        "urls": ["next.html", "next2.html"]
      }
    ]
  }
</script>

यह नियम सेट, खास पेजों के पूरी तरह लोड और रेंडर को ट्रिगर करता है. हालांकि, इसमें कुछ पाबंदियां लागू होती हैं. इसकी मदद से, कॉन्टेंट को तुरंत लोड किया जा सकता है—हालांकि, इसके लिए अतिरिक्त संसाधन का इस्तेमाल करना पड़ता है.

हालांकि, ये प्रीफ़ेच नेटवर्क पैनल में उपलब्ध नहीं होते हैं, क्योंकि इन्हें Chrome में रेंडर करने की एक अलग प्रोसेस में फ़ेच और रेंडर किया जाता है. इससे, अनुमान के हिसाब से लोड होने की सुविधा वाले टैब को प्रीरेंडरिंग की अनुमान लगाने से जुड़े नियमों को डीबग करने में मदद मिलती है.

अनुमान के हिसाब से लोड होने वाले टैब की मदद से, prerender को डीबग करें

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

Chrome DevTools, अनुमान के आधार पर प्रीरेंडरिंग अनुमान के नियमों वाले पेज के लिए टैब लोड करता है
Chrome DevTools अनुमान के आधार पर, प्रीरेंडरिंग अनुमान के नियम वाले पेज के लिए टैब लोड होते हैं

यहां हमें फिर से पता चला है कि तीन में से एक यूआरएल पहले से रेंडर नहीं किया जा सका. साथ ही, डेवलपर 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 के अनुमान वाले टैब में, ट्रिगर नहीं किए गए कई यूआरएल हैं
Chrome DevTools के अनुमान वाले टैब में, ट्रिगर नहीं किए गए कई यूआरएल मौजूद हैं

स्टेटस ट्रिगर नहीं किया गया है, क्योंकि इनके लिए प्रीरेंडरिंग प्रोसेस शुरू नहीं हुई है. हालांकि, जब हम पॉइंटर को लिंक के ऊपर रखते हैं, तो हर यूआरएल को प्रीरेंडरिंग किए जाने पर, हमें स्टेटस में बदलाव दिखता है:

Chrome DevTools के अनुमान टैब में, पहले से रेंडर किए गए पेज ट्रिगर किए गए
Chrome DevTools अनुमान टैब, जिसमें पहले से रेंडर किए गए पेज ट्रिगर किए गए हैं

Chrome ने पहले से रेंडर करने की सीमा तय की है, जिसमें moderate eagerness के लिए ज़्यादा से ज़्यादा 2 प्रीरेंडरिंग शामिल हैं, इसलिए तीसरे लिंक पर कर्सर घुमाने के बाद, हमें उस यूआरएल की गड़बड़ी की वजह पता चलती है:

Chrome DevTools के अनुमान वाला टैब, जिसमें पहले से लोड नहीं किए जा सके गड़बड़ी की जानकारी दिख रही है
Chrome DevTools के अनुमान वाले टैब में, पहले से लोड नहीं किए जा सके नतीजे दिख रहे हैं

prerender को अन्य DevTools पैनल की मदद से डीबग करें

प्रीफ़ेच से अलग, नेटवर्क पैनल जैसे DevTools पैनल में रेंडर करने की मौजूदा प्रोसेस में, पहले से रेंडर किए गए पेज नहीं दिखेंगे. ऐसा इसलिए होता है, क्योंकि उन्हें पर्दे के पीछे की गतिविधियों को रेंडर करने वाले अपने खुद के पेज में रेंडर किया जाता है.

हालांकि, अब DevTools पैनल में इस्तेमाल किए गए रेंडरर को स्विच किया जा सकता है. इसके लिए, सबसे ऊपर दाईं ओर मौजूद ड्रॉप-डाउन मेन्यू का इस्तेमाल करें. इसके अलावा, पैनल के सबसे ऊपर वाले हिस्से में किसी यूआरएल को चुनकर और जांच करें विकल्प को चुनकर भी ऐसा किया जा सकता है:

Chrome DevTools की मदद से अब उन रेंडरर को बदला जा सकता है जिनके लिए जानकारी दिखती है
Chrome DevTools की मदद से अब, रेंडर करने वाले उस टूल पर स्विच किया जा सकता है जिसके लिए जानकारी दिखती है

इस ड्रॉप डाउन और चुनी गई वैल्यू को अन्य सभी पैनल के साथ भी शेयर किया जाता है. उदाहरण के लिए, नेटवर्क पैनल. यहां यह देखा जा सकता है कि अनुरोध किया गया पेज, पहले से रेंडर किया गया पेज है:

Chrome DevTools नेटवर्क पैनल, जो पहले से रेंडर किए गए पेज के नेटवर्क अनुरोधों को दिखाता है
Chrome DevTools नेटवर्क पैनल, जो पहले से रेंडर किए गए पेज के नेटवर्क अनुरोध दिखाता है

इन संसाधनों के एचटीटीपी हेडर देखें. इससे हमें पता चलता है कि वे सभी Sec-Purpose: prefetch;prerender हेडर के साथ सेट हैं:

Chrome DevTools नेटवर्क पैनल, जिसमें पहले से रेंडर किए गए पेज का सीक्रेट हेडर दिख रहा है
Chrome DevTools नेटवर्क पैनल, जिसमें पहले से रेंडर किए गए पेज का Sec-purpose हेडर दिख रहा है

इसके अलावा, एलिमेंट पैनल, जहां पेज का कॉन्टेंट देखा जा सकता है. उदाहरण के लिए, इस स्क्रीनशॉट में दिखाया गया है कि <h1> एलिमेंट पहले से रेंडर किए गए पेज के लिए है:

पहले से रेंडर किए गए पेज के लिए Chrome DevTools एलिमेंट पैनल
पहले से रेंडर किए गए पेज के लिए, Chrome DevTools एलिमेंट पैनल

इसके अलावा, कंसोल पैनल में, पहले से रेंडर किए गए पेज से उत्सर्जित कंसोल लॉग देखे जा सकते हैं:

Chrome DevTools कंसोल पैनल, जिसमें पहले से रेंडर किए गए पेज से कंसोल आउटपुट दिखाया गया है
Chrome DevTools कंसोल पैनल, जिसमें पहले से रेंडर किए गए पेज से कंसोल आउटपुट दिखाया गया है

पहले से रेंडर किए गए पेज पर, अनुमान लगाने के नियमों को डीबग करना

पिछले सेक्शन में, पेज पर पहले से रेंडर किए गए उन पेजों को डीबग करने के तरीके के बारे में बताया गया है जो प्रीरेंडरिंग की शुरुआत करते हैं. हालांकि, पहले से रेंडर किए गए पेज भी डीबग करने की जानकारी दे सकते हैं. इसके लिए, Analytics कॉल या कंसोल में लॉग इन किया जा सकता है (इस बारे में पिछले सेक्शन में बताया गया है).

इसके अलावा, जब उपयोगकर्ता पहले से रेंडर किए गए पेज पर जाता है, तो अनुमान के हिसाब से लोड होना टैब इस स्थिति को दिखाता है. साथ ही, इस स्थिति में यह जानकारी भी दिखती है कि उसे पहले से रेंडर किया गया या नहीं. अगर इसे प्रीरेंडर नहीं किया जा सका, तो इस बारे में जानकारी न दें कि ऐसा क्यों किया गया था:

Chrome DevTools &#39;अनुमान के मुताबिक लोड&#39; टैब, पहले से रेंडर किया गया ऐसा पेज है जो कामयाब रहा और नहीं हो सका
Chrome DevTools का अनुमान के हिसाब से लोड होने वाला टैब, पहले से रेंडर किया गया ऐसा पेज दिखाता है जो कामयाब रहा है और रेंडर नहीं हो सका

इसके अलावा—जैसा कि प्रीफ़ेच के मामले में होता है—अगर अनुमान लगाने के नियम मौजूदा पेज से मेल नहीं खाते, उस पेज से नेविगेट करने पर, आपको यह दिखाने की कोशिश की जाएगी कि यूआरएल, अनुमान के लोड होने की जानकारी टैब में, पिछले पेज पर अनुमान लगाने के नियमों में शामिल यूआरएल से मेल क्यों नहीं खाते:

Chrome DevTools के अनुमान के हिसाब से लोड होने वाले पेज का टैब, जिसमें मौजूदा यूआरएल और पिछले पेज से कवर किए गए यूआरएल से मेल न खाने वाला यूआरएल दिखाया गया है
यूआरएल के मेल न खाने की जानकारी देने वाला Chrome DevTools

नतीजा

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

स्वीकार हैं

Unsplash पर, न्यूबेल्सन फ़र्नांडीस की थंबबेल इमेज.