अनुमान लगाने के नियम वाले एपीआई में सुधार

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

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

अतिरिक्त सुविधाएं

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

दस्तावेज़ के नियम

पहले, अनुमान लगाने के नियमों वाला एपीआई, प्रीफ़ेच या प्री-रेंडर करने के लिए यूआरएल की सूची तय करके काम करता था:

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

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

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

इसके अलावा, हम दस्तावेज़ के नियमों का इस्तेमाल करके, लिंक अपने-आप ढूंढने का एक नया विकल्प उपलब्ध करा रहे हैं. यह where शर्त के आधार पर, दस्तावेज़ से यूआरएल सोर्स करता है. यह लिंक पर आधारित हो सकता है:

<script type="speculationrules">
{
  "prerender": [{
    "source": "document",
    "where": {
      "and": [
        { "href_matches": "/*" },
        { "not": {"href_matches": "/logout/*"}}
      ]
    },
    "eagerness": "moderate"
  }]
}
</script>

मौजूदा पेज में लिंक ढूंढने के लिए, सीएसएस सिलेक्टर का इस्तेमाल, href मैच के साथ या इसके विकल्प के तौर पर भी किया जा सकता है:

<script type="speculationrules">
{
  "prerender": [{
    "source": "document",
    "where": {
      "and": [
        { "selector_matches": ".prerender" },
        { "not": {"selector_matches": ".do-not-prerender"}}
      ]
    },
    "eagerness": "moderate"
  }]
}
</script>

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

बेशक, किसी पेज पर सभी लिंक को पहले से रेंडर करना बेकार होगा. इसलिए, इस नई सुविधा के साथ, हमने eagerness सेटिंग को जोड़ा है.

उत्सुकता

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

दूसरी ओर, जब कोई उपयोगकर्ता किसी लिंक पर क्लिक करता है, तब ही पेज को प्री-रेंडर करने से, बैंडविड्थ का इस्तेमाल कम होता है. हालांकि, इससे लीड मिलने में लगने वाला समय भी कम हो जाता है. इसका मतलब है कि ब्राउज़र उस पेज पर स्विच करने से पहले, हो सकता है कि पेज को पहले से रेंडर करने की प्रोसेस पूरी न हुई हो.

eagerness सेटिंग की मदद से, यह तय किया जा सकता है कि अनुमान कब चलाए जाएं. साथ ही, यह भी तय किया जा सकता है कि किन यूआरएल के लिए अनुमान लगाए जाएं. इसके लिए, कब को अलग किया जाता है. eagerness सेटिंग, list और document, दोनों सोर्स नियमों के लिए उपलब्ध है. इसमें चार सेटिंग हैं, जिनके लिए Chrome में ये हेयुरिस्टिक्स हैं:

  • immediate: इसका इस्तेमाल, अनुमान लगाने के लिए जल्द से जल्द किया जाता है. इसका मतलब है कि अनुमान लगाने के नियमों का पालन होते ही, इसका इस्तेमाल किया जाता है.
  • eager: फ़िलहाल, यह immediate सेटिंग की तरह ही काम करती है. हालांकि, आने वाले समय में हम इसे immediate और moderate के बीच में रखना चाहते हैं.
  • moderate: अगर किसी लिंक पर 200 मिलीसेकंड तक कर्सर घुमाया जाता है, तो यह अनुमान लगाता है. अगर pointerdown इवेंट पहले होता है, तो यह उस पर अनुमान लगाता है. साथ ही, मोबाइल पर जहां hover इवेंट नहीं होता है वहां भी यह अनुमान लगाता है.
  • conservative: इससे पॉइंटर या टच डाउन का अनुमान लगाया जाता है.

list नियमों के लिए डिफ़ॉल्ट eagerness immediate है. moderate और conservative विकल्पों का इस्तेमाल करके, list नियमों को उन यूआरएल तक सीमित किया जा सकता है जिनसे उपयोगकर्ता किसी खास सूची के साथ इंटरैक्ट करता है. हालांकि, कई मामलों में where शर्त वाले document नियम ज़्यादा सही हो सकते हैं.

document नियमों के लिए डिफ़ॉल्ट eagerness conservative है. किसी दस्तावेज़ में कई यूआरएल हो सकते हैं. इसलिए, document नियमों के लिए immediate या eager का इस्तेमाल सावधानी से करना चाहिए. इसके बाद, Chrome की सीमाएं सेक्शन भी देखें.

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

moderate विकल्प, एक मध्यम विकल्प है. कई साइटों को, अनुमान लगाने के इस आसान नियम से फ़ायदा मिल सकता है. यह नियम, अनुमान लगाने के बुनियादी और असरदार नियमों को लागू करने के तौर पर, कर्सर घुमाने या पॉइंटर को नीचे ले जाने पर सभी लिंक को पहले से रेंडर कर देगा:

<script type="speculationrules">
{
  "prerender": [{
    "source": "document",
    "where": {
      "href_matches": "/*"
    },
    "eagerness": "moderate"
  }]
}
</script>

Chrome की सीमाएं

eagerness का विकल्प चुनने पर भी, Chrome में इस एपीआई के ज़रूरत से ज़्यादा इस्तेमाल को रोकने के लिए कुछ सीमाएं हैं:

eagerness प्रीफ़ेच प्रीरेंडर
immediate / eager 50 10
moderate / conservative 2 (एफ़आईएफ़ओ) 2 (एफ़आईएफ़ओ)
Chrome में अनुमान लगाने की सीमाएं

moderate और conservative सेटिंग, पहले आओ पहले पाओ (FIFO) के तरीके से काम करती हैं. ये सेटिंग, उपयोगकर्ता के इंटरैक्शन पर निर्भर करती हैं. सीमा तक पहुंचने के बाद, नया अनुमान लगाने पर, सबसे पुराना अनुमान रद्द हो जाएगा और मेमोरी बचाने के लिए, नए अनुमान से बदल दिया जाएगा.

moderate और conservative के अनुमान, उपयोगकर्ताओं की ओर से ट्रिगर किए जाते हैं. इस वजह से, हम मेमोरी बचाने के लिए, दो के थ्रेशोल्ड का इस्तेमाल कर सकते हैं. immediate और eager सेटिंग, उपयोगकर्ता की कार्रवाई से ट्रिगर नहीं होती हैं. इसलिए, इनकी सीमा ज़्यादा होती है. ऐसा इसलिए है, क्योंकि ब्राउज़र यह नहीं जान सकता कि किन सेटिंग की ज़रूरत है और कब ज़रूरत है.

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

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

Chrome, कुछ स्थितियों में अनुमान का इस्तेमाल होने से भी रोकेगा. इन स्थितियों में ये शामिल हैं:

  • Save-Data.
  • एनर्जी सेवर.
  • मेमोरी की सीमाएं.
  • "पेजों को पहले से लोड करें" सेटिंग बंद होने पर. यह सेटिंग, uBlock Origin जैसे Chrome एक्सटेंशन से भी साफ़ तौर पर बंद की जा सकती है.
  • बैकग्राउंड टैब में खोले गए पेज.

इन सभी शर्तों का मकसद, उपयोगकर्ताओं को नुकसान पहुंचाने वाली अटकलों के असर को कम करना है.

ज़रूरी नहीं source

Chrome 122 में source बटन को वैकल्पिक बना दिया गया है. इसकी वजह यह है कि url या where बटन की मौजूदगी से, source बटन की जानकारी मिल जाती है. इसलिए, अनुमान लगाने के ये दोनों नियम एक जैसे हैं:

<script type="speculationrules">
{
  "prerender": [{
    "source": "document",
    "where": { "href_matches": "/*" },
    "eagerness": "moderate"
  }]
}
</script>
<script type="speculationrules">
{
  "prerender": [{
    "where": { "href_matches": "/*" },
    "eagerness": "moderate"
  }]
}
</script>

Speculation-Rules एचटीटीपी हेडर

अनुमान के नियमों को सीधे दस्तावेज़ के एचटीएमएल में शामिल करने के बजाय, Speculation-Rules एचटीटीपी हेडर का इस्तेमाल करके भी डिलीवर किया जा सकता है. इससे सीडीएन के ज़रिए, दस्तावेज़ के कॉन्टेंट में बदलाव किए बिना, उसे आसानी से डिप्लॉय किया जा सकता है.

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

Speculation-Rules: "/speculationrules.json"

इस संसाधन के लिए, सही MIME टाइप का इस्तेमाल करना ज़रूरी है. अगर यह क्रॉस-ऑरिजिन संसाधन है, तो CORS जांच पास करना ज़रूरी है.

Content-Type: application/speculationrules+json
Access-Control-Allow-Origin: *

अगर आपको रिलेटिव यूआरएल का इस्तेमाल करना है, तो अपने अनुमान के नियमों में "relative_to": "document" कुंजी शामिल करें. ऐसा न करने पर, रिलेटिव यूआरएल, अनुमान लगाने के नियमों की JSON फ़ाइल के यूआरएल के हिसाब से होंगे. यह सुविधा खास तौर पर तब काम आ सकती है, जब आपको एक ही ऑरिजिन वाले कुछ या सभी लिंक चुनने हों.

कैश मेमोरी का बेहतर तरीके से दोबारा इस्तेमाल करना

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

इससे, फिर से अनुमान लगाने की प्रोसेस (उदाहरण के लिए, moderate ईगरनेस सेटिंग वाले दस्तावेज़ के नियमों के लिए) काफ़ी सस्ती हो जाती है. ऐसा इसलिए होता है, क्योंकि Chrome, कैश मेमोरी में सेव किए जा सकने वाले संसाधनों के लिए एचटीटीपी कैश का इस्तेमाल करेगा.

हम कैश मेमोरी के फिर से इस्तेमाल को बेहतर बनाने के लिए, No-Vary-Search के नए प्रस्ताव का भी समर्थन करते हैं.

No-Vary-Search सहायता

किसी पेज को पहले से लोड करने या पहले से रेंडर करने पर, हो सकता है कि कुछ यूआरएल पैरामीटर (जिन्हें तकनीकी तौर पर सर्च पैरामीटर कहा जाता है) सर्वर से डिलीवर किए गए पेज के लिए ज़रूरी न हों. इनका इस्तेमाल सिर्फ़ क्लाइंट साइड JavaScript करता है.

उदाहरण के लिए, Google Analytics, कैंपेन मेज़रमेंट के लिए UTM पैरामीटर का इस्तेमाल करता है. हालांकि, आम तौर पर इससे सर्वर से अलग-अलग पेज डिलीवर नहीं होते. इसका मतलब है कि page1.html?utm_content=123 और page1.html?utm_content=456, सर्वर से एक ही पेज डिलीवर करेंगे. इसलिए, उसी पेज का फिर से इस्तेमाल कैश मेमोरी से किया जा सकता है.

इसी तरह, ऐप्लिकेशन ऐसे अन्य यूआरएल पैरामीटर का इस्तेमाल कर सकते हैं जिन्हें सिर्फ़ क्लाइंट साइड पर मैनेज किया जाता है.

No-Vary-Search प्रोसेस की मदद से, सर्वर ऐसे पैरामीटर तय कर सकता है जिनसे डिलीवर किए गए संसाधन में कोई फ़र्क़ नहीं पड़ता. इसलिए, ब्राउज़र किसी दस्तावेज़ के उन वर्शन का फिर से इस्तेमाल कर सकता है जिन्हें पहले कैश किया गया था और जो सिर्फ़ इन पैरामीटर में अलग-अलग हैं. ध्यान दें: फ़िलहाल, यह सुविधा सिर्फ़ Chrome (और Chromium पर आधारित ब्राउज़र) में, नेविगेशन के अनुमान को पहले से लोड करने के लिए काम करती है.

अनुमान के नियमों में expects_no_vary_search का इस्तेमाल किया जा सकता है. इससे यह पता चलता है कि No-Vary-Search एचटीटीपी हेडर कहां दिख सकता है. ऐसा करने से, अनचाहे डाउनलोड से भी बचा जा सकता है.

<script type="speculationrules">
{
  "prefetch": [{
    "urls": ["/products*"],
    "expects_no_vary_search": "params=(\"id\")"
  }]
}
</script>

<a href="/products?id=123">Product 123</a>
<a href="/products?id=124">Product 124</a>

इस उदाहरण में, प्रॉडक्ट आईडी 123 और 124, दोनों के लिए /products शुरुआती पेज का एचटीएमएल एक ही है. हालांकि, id सर्च पैरामीटर का इस्तेमाल करके प्रॉडक्ट डेटा फ़ेच करने के लिए, JavaScript का इस्तेमाल करके क्लाइंट-साइड रेंडरिंग के आधार पर, पेज का कॉन्टेंट अलग-अलग होता है. इसलिए, हम उस यूआरएल को पहले से लोड कर लेते हैं. इससे, हमें No-Vary-Search एचटीटीपी हेडर मिलता है, जिसमें यह जानकारी होती है कि पेज का इस्तेमाल किसी भी id सर्च पैरामीटर के लिए किया जा सकता है.

हालांकि, अगर उपयोगकर्ता प्रीफ़ेच पूरा होने से पहले किसी भी लिंक पर क्लिक करता है, तो हो सकता है कि ब्राउज़र को /products पेज न मिला हो. इस मामले में, ब्राउज़र को नहीं पता कि इसमें No-Vary-Search एचटीटीपी हेडर शामिल होगा या नहीं. इसके बाद, ब्राउज़र के पास यह चुनने का विकल्प होता है कि उसे लिंक को फिर से फ़ेच करना है या प्रीफ़ेच की प्रोसेस पूरी होने का इंतज़ार करना है, ताकि यह देखा जा सके कि उसमें No-Vary-Search एचटीटीपी हेडर है या नहीं. expects_no_vary_search सेटिंग की मदद से, ब्राउज़र को यह पता चलता है कि पेज के रिस्पॉन्स में No-Vary-Search एचटीटीपी हेडर शामिल हो सकता है. साथ ही, यह भी पता चलता है कि प्रीफ़ेच की प्रोसेस पूरी होने का इंतज़ार करना है या नहीं.

डेमो

हमने https://speculative-rules.glitch.me/common-fruits.html पर एक डेमो बनाया है. इसका इस्तेमाल, moderate ईगरनेस सेटिंग के साथ दस्तावेज़ के नियमों को देखने के लिए किया जा सकता है:

गड़बड़ी की वजह से बनाई गई डेमो साइट का स्क्रीनशॉट, जिसमें फ़लों के लेबल वाले कई लिंक मौजूद हैं. DevTools खुला है और इसमें दिख रहा है कि दो लिंक (apple.html और orange.html) पहले से ही प्री-रेंडर हो चुके हैं.
अनुमान लगाने के नियमों का डेमो

DevTools खोलें और ऐप्लिकेशन पैनल पर क्लिक करें. इसके बाद, बैकग्राउंड सेवाएं सेक्शन में, अनुमानित लोड पर क्लिक करें. इसके बाद, अनुमान पैनल पर क्लिक करें और स्थिति कॉलम के हिसाब से क्रम से लगाएं.

फलों पर कर्सर घुमाने पर, आपको पेज प्री-रेंडरिंग करते हुए दिखेंगे. उन पर क्लिक करने से, पहले से रेंडर नहीं की गई किसी रेसिपी के मुकाबले एलसीपी का समय काफ़ी कम दिखेगा. इस डेमो के बारे में इस वीडियो में भी बताया गया है:

अटकलों के नियमों को डीबग करने के लिए, DevTools का इस्तेमाल करने के तरीके के बारे में ज़्यादा जानने के लिए, अटकलों के नियमों को डीबग करने के बारे में पिछली ब्लॉग पोस्ट देखें.

अनुमान लगाने के नियमों के लिए प्लैटफ़ॉर्म की सहायता

अनुमान लगाने के नियमों को <script type="speculationrules"> एलिमेंट में इंजेक्ट करके लागू करना आसान है. हालांकि, प्लैटफ़ॉर्म के सहायता से, इसे एक क्लिक में लागू किया जा सकता है. हम अलग-अलग प्लैटफ़ॉर्म और पार्टनर के साथ काम कर रहे हैं, ताकि सट्टेबाज़ी के ख़िलाफ़ बने नियमों को आसानी से लागू किया जा सके.

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

WordPress

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

सेटिंग के दो ग्रुप उपलब्ध हैं: अनुमान मोड और इच्छा सेटिंग:

WordPress की सेटिंग वाले रीडिंग पैनल का स्क्रीनशॉट, जिसमें अनुमान लगाने के नियमों की सेटिंग मौजूद हैं. इसके दो विकल्प हैं: अनुमान मोड, जिसमें प्रीफ़ेच या प्री-रेंडर करने का विकल्प होता है. साथ ही, कंज़र्वेटिव, मॉडरेट या ईगर सेटिंग वाली ईगरनेस सेटिंग.
WordPress पर अनुमान लगाने के नियमों का पालन करने वाला प्लगिन

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

Akamai

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

NitroPack

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

Chrome की टीम ने NitroPack के साथ मिलकर, स्पिक्युलेशन रूल्स एपीआई के लिए वेबिनार पर भी काम किया. इस वेबिनार में, इस बारे में ज़्यादा जानकारी दी गई है कि अनुमान लगाने के लिए, जल्दी और बार-बार या देर से और कम बार क्या करना चाहिए.

एस्ट्रो

Astro ने प्रयोग के तौर पर, 4.2 में Speculation Rules API का इस्तेमाल करके पेजों को पहले से रेंडर करने की सुविधा जोड़ी है. इससे Astro का इस्तेमाल करने वाले डेवलपर, इस सुविधा को आसानी से चालू कर सकते हैं. साथ ही, Speculation Rules API के साथ काम न करने वाले ब्राउज़र के लिए, स्टैंडर्ड प्रीफ़ेच का इस्तेमाल किया जा सकता है. ज़्यादा जानकारी के लिए, क्लाइंट प्री-रेंडर दस्तावेज़ पढ़ें.

नतीजा

अनुमान के नियमों वाले एपीआई में किए गए इन बदलावों से, साइटों के लिए परफ़ॉर्मेंस की इस नई सुविधा का इस्तेमाल ज़्यादा आसानी से किया जा सकता है. साथ ही, अनुमान के गलत इस्तेमाल से संसाधनों को बर्बाद होने का जोखिम भी कम हो जाता है. हमें यह देखकर खुशी हो रही है कि कुछ प्लैटफ़ॉर्म पहले से ही इस एपीआई का इस्तेमाल कर रहे हैं. हमें उम्मीद है कि साल 2024 में इस एपीआई का ज़्यादा से ज़्यादा इस्तेमाल किया जाएगा. इससे, असली उपयोगकर्ताओं को बेहतर परफ़ॉर्मेंस मिलेगी.

स्पेसप्लेस के नियमों वाले एपीआई से परफ़ॉर्मेंस में होने वाली बढ़ोतरी के अलावा, हमें यह देखने में भी दिलचस्पी है कि इससे कौनसे नए अवसर मिलेंगे. व्यू ट्रांज़िशन एक नया एपीआई है. इसकी मदद से, डेवलपर नेविगेशन के बीच ट्रांज़िशन को आसानी से तय कर सकते हैं. फ़िलहाल, यह सुविधा सिंगल पेज ऐप्लिकेशन (एसपीए) के लिए उपलब्ध है. हालांकि, मल्टी-पेज वर्शन पर काम चल रहा है. यह सुविधा, Chrome में फ़्लैग के पीछे उपलब्ध है. प्री-रेंडर, इस सुविधा का एक स्वाभाविक ऐड-ऑन है. इससे यह पक्का किया जाता है कि कोई देरी न हो. देरी होने पर, ट्रांज़िशन से उपयोगकर्ता अनुभव को बेहतर बनाने में मदद नहीं मिलती. हमने पहले ही कुछ साइटों को इस कॉम्बिनेशन के साथ एक्सपेरिमेंट करते हुए देखा है.

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

आभार

Unsplash पर Robbie Down का थंबनेल