इस कोडलैब में, कुछ रिसॉर्स को प्रीलोड और प्रीफ़ेच करके, नीचे दिए गए वेब पेज की परफ़ॉर्मेंस को बेहतर बनाया गया है:
मापें
कोई भी ऑप्टिमाइज़ेशन जोड़ने से पहले, यह मेज़र करें कि वेबसाइट की परफ़ॉर्मेंस कैसी है.
- साइट की झलक देखने के लिए, ऐप्लिकेशन देखें दबाएं. इसके बाद, फ़ुलस्क्रीन दबाएं.
अपने Glitch के लाइव वर्शन पर, लाइटहाउस परफ़ॉर्मेंस ऑडिट (Lighthouse > विकल्प > परफ़ॉर्मेंस) चलाएं. साथ ही, Lighthouse की मदद से परफ़ॉर्मेंस से जुड़े अवसरों को ढूंढें लेख भी पढ़ें.
Lighthouse, देर से फ़ेच किए गए रिसॉर्स के लिए, ऑडिट में फ़ेल होने का यह मैसेज दिखाता है:
- DevTools खोलने के लिए, `Control+Shift+J` दबाएं. Mac पर, `Command+Option+J` दबाएं.
- नेटवर्क टैब पर क्लिक करें.
main.css
फ़ाइल को एचटीएमएल दस्तावेज़ में मौजूद लिंक एलिमेंट (<link>
) से फ़ेच नहीं किया जाता. इसके बजाय, fetch-css.js
नाम की एक अलग JavaScript फ़ाइल, window.onLoad
इवेंट के बाद लिंक एलिमेंट को डीओएम से जोड़ती है. इसका मतलब है कि ब्राउज़र, JS फ़ाइल को पार्स और एक्ज़ीक्यूट करने के बाद ही फ़ाइल को फ़ेच करता है. इसी तरह, main.css
में बताए गए वेब फ़ॉन्ट (K2D.woff2
) को सिर्फ़ तब फ़ेच किया जाता है, जब सीएसएस फ़ाइल डाउनलोड हो जाती है.
अहम अनुरोध चेन, उन संसाधनों के क्रम को दिखाती है जिन्हें ब्राउज़र प्राथमिकता देता है और फ़ेच करता है. फ़िलहाल, इस वेब पेज का दिखने का तरीका कुछ ऐसा है:
├─┬ / (initial HTML file)
└── fetch-css.js
└── main.css
└── K2D.woff2
सीएसएस फ़ाइल, अनुरोध चेन के तीसरे लेवल पर है. इसलिए, Lighthouse ने इसे देर से खोजे गए रिसॉर्स के तौर पर पहचाना है.
ज़रूरी रिसॉर्स प्रीलोड करना
main.css
फ़ाइल एक अहम एसेट है, जिसकी ज़रूरत पेज लोड होने के तुरंत बाद पड़ती है. इस रिसॉर्स जैसी अहम फ़ाइलों के लिए, लिंक प्रीलोड टैग का इस्तेमाल करें. इससे ब्राउज़र को यह जानकारी मिलती है कि उसे जल्दी डाउनलोड किया जाए. इसके लिए, दस्तावेज़ के हेड में लिंक एलिमेंट जोड़ें.
इस ऐप्लिकेशन के लिए, प्रीलोड टैग जोड़ें:
<head>
<!-- ... -->
<link rel="preload" href="main.css" as="style">
</head>
as
एट्रिब्यूट का इस्तेमाल, यह पता लगाने के लिए किया जाता है कि किस तरह का संसाधन फ़ेच किया जा रहा है. साथ ही, as="style"
का इस्तेमाल स्टाइलशीट फ़ाइलों को प्रीलोड करने के लिए किया जाता है.
ऐप्लिकेशन को फिर से लोड करें और DevTools में नेटवर्क पैनल देखें.
ध्यान दें कि ब्राउज़र, सीएसएस फ़ाइल को फ़ेच करने से पहले ही, उसे फ़ेच करने के लिए ज़िम्मेदार जावास्क्रिप्ट को पार्स कर लेता है. प्रीफ़ेच की मदद से, ब्राउज़र को यह पता चल जाता है कि किसी संसाधन को पहले से फ़ेच करना ज़रूरी है. ऐसा इस आधार पर किया जाता है कि वह संसाधन वेब पेज के लिए ज़रूरी है.
अगर इसका इस्तेमाल सही तरीके से नहीं किया जाता है, तो प्रीलोड की सुविधा, ऐसे संसाधनों के लिए ज़रूरत से ज़्यादा अनुरोध करके परफ़ॉर्मेंस पर असर डाल सकती है जिनका इस्तेमाल नहीं किया जाता. इस ऐप्लिकेशन में, details.css
एक ऐसी सीएसएस फ़ाइल है जो प्रोजेक्ट के रूट में मौजूद होती है. हालांकि, इसका इस्तेमाल एक अलग /details route
के लिए किया जाता है. पहले से लोड किए गए डेटा का गलत तरीके से इस्तेमाल कैसे किया जा सकता है, इसका उदाहरण दिखाने के लिए, इस संसाधन के लिए भी पहले से लोड किए गए डेटा का संकेत जोड़ें.
<head>
<!-- ... -->
<link rel="preload" href="main.css" as="style">
<link rel="preload" href="details.css" as="style">
</head>
ऐप्लिकेशन को फिर से लोड करें और नेटवर्क पैनल देखें.
details.css
को वापस पाने का अनुरोध किया जाता है, भले ही वेब पेज उसका इस्तेमाल न कर रहा हो.
जब पेज पर पहले से लोड किए गए किसी संसाधन का इस्तेमाल, लोड होने के कुछ सेकंड के अंदर नहीं किया जाता, तो Chrome कंसोल पैनल में चेतावनी दिखाता है.
इस चेतावनी का इस्तेमाल इंडिकेटर के तौर पर करें. इससे यह पता चलता है कि आपके पास ऐसे पहले से लोड किए गए रिसॉर्स हैं या नहीं, जिनका इस्तेमाल आपके वेब पेज पर तुरंत नहीं किया जा रहा है. अब इस पेज के लिए, प्रीलोड किए जाने वाले ज़रूरत के मुताबिक न होने वाले लिंक को हटाया जा सकता है.
<head>
<!-- ... -->
<link rel="preload" href="main.css" as="style">
<link rel="preload" href="details.css" as="style">
</head>
as
एट्रिब्यूट के लिए इस्तेमाल की जा सकने वाली सही वैल्यू के साथ-साथ, फ़ेच किए जा सकने वाले सभी तरह के संसाधनों की सूची के लिए, प्रीलोड करने के बारे में MDN का लेख पढ़ें.
आने वाले समय में इस्तेमाल होने वाले संसाधनों को पहले से लोड करना
पहले से फ़ेच करना, ब्राउज़र का एक और हिंट है. इसका इस्तेमाल, किसी दूसरे नेविगेशन रूट के लिए इस्तेमाल की जाने वाली ऐसेट का अनुरोध करने के लिए किया जा सकता है. हालांकि, इसकी प्राथमिकता, मौजूदा पेज के लिए ज़रूरी अन्य अहम ऐसेट से कम होती है.
इस वेबसाइट में, इमेज पर क्लिक करने से आपको एक अलग details/
रास्ते पर ले जाया जाता है.
details.css
नाम की एक अलग सीएसएस फ़ाइल में, इस आसान पेज के लिए ज़रूरी सभी स्टाइल मौजूद हैं. इस संसाधन को पहले से लोड करने के लिए, index.html
में लिंक एलिमेंट जोड़ें.
<head>
<!-- ... -->
<link rel="prefetch" href="details.css">
</head>
यह समझने के लिए कि इससे फ़ाइल के लिए अनुरोध कैसे ट्रिगर होता है, DevTools में नेटवर्क पैनल खोलें और कैश मेमोरी बंद करें विकल्प से सही का निशान हटाएं.
ऐप्लिकेशन को फिर से लोड करें और देखें कि अन्य सभी फ़ाइलें फ़ेच होने के बाद, details.css
के लिए बहुत कम प्राथमिकता वाला अनुरोध कैसे किया जाता है.
DevTools खोलकर, details
पेज पर जाने के लिए वेबसाइट पर मौजूद इमेज पर क्लिक करें.
details.css
को फ़ेच करने के लिए, details.html
में लिंक एलिमेंट का इस्तेमाल किया जाता है. इसलिए, उम्मीद के मुताबिक संसाधन के लिए अनुरोध किया जाता है.
details.css
नेटवर्क अनुरोध की जानकारी देखने के लिए, DevTools में उस पर क्लिक करें. आपको पता चलेगा कि फ़ाइल, ब्राउज़र की डिस्क कैश मेमोरी से वापस लाई गई है.
ब्राउज़र के इंतज़ार के समय का फ़ायदा उठाकर, प्रीफ़ेच किसी दूसरे पेज के लिए ज़रूरी रिसॉर्स का अनुरोध पहले कर देता है. इससे ब्राउज़र, एसेट को जल्द से जल्द कैश मेमोरी में सेव कर पाता है और ज़रूरत पड़ने पर कैश मेमोरी से दिखा पाता है. इससे, आने वाले समय में नेविगेशन के अनुरोधों की स्पीड बढ़ जाती है.
webpack की मदद से, पहले से लोड करना और प्रीफ़ेच करना
कोड को अलग-अलग करके JavaScript के पेलोड को कम करना पोस्ट में, किसी बंडल को कई हिस्सों में बांटने के लिए डाइनैमिक इंपोर्ट के इस्तेमाल के बारे में बताया गया है. इसे एक आसान ऐप्लिकेशन की मदद से दिखाया गया है, जो फ़ॉर्म सबमिट होने पर Lodash से मॉड्यूल को डाइनैमिक तौर पर इंपोर्ट करता है.
इस ऐप्लिकेशन के लिए Glitch को यहां ऐक्सेस किया जा सकता है.
src/index.js,
में मौजूद कोड का यह ब्लॉक, बटन पर क्लिक करने पर, डाइनैमिक तौर पर तरीका इंपोर्ट करने के लिए ज़िम्मेदार है.
form.addEventListener("submit", e => {
e.preventDefault()
import('lodash.sortby')
.then(module => module.default)
.then(sortInput())
.catch(err => { alert(err) });
});
बंडल को अलग-अलग हिस्सों में बांटने से, उसके शुरुआती साइज़ को कम किया जा सकता है. इससे, पेज लोड होने में लगने वाला समय कम हो जाता है. webpack के 4.6.0 वर्शन में, डाइनैमिक तौर पर इंपोर्ट किए गए चंक को पहले से लोड करने या पहले से लोड होने की सुविधा मिलती है. उदाहरण के लिए, इस ऐप्लिकेशन का इस्तेमाल करके, ब्राउज़र के खाली समय में lodash
तरीके को पहले से फ़ेच किया जा सकता है. जब कोई उपयोगकर्ता बटन दबाता है, तो संसाधन को फ़ेच करने में कोई देरी नहीं होती.
किसी हिस्से को प्रीफ़ेच करने के लिए, डाइनैमिक इंपोर्ट में टिप्पणी के webpackPrefetch
पैरामीटर का इस्तेमाल करें.
इस ऐप्लिकेशन में यह सुविधा कैसी दिखेगी, यहां देखें.
form.addEventListener("submit", e => {
e.preventDefault()
import(/* webpackPrefetch: true */ 'lodash.sortby')
.then(module => module.default)
.then(sortInput())
.catch(err => { alert(err) });
});
ऐप्लिकेशन फिर से लोड होने के बाद, वेबपैक दस्तावेज़ के हेड में, संसाधन के लिए प्रीफ़ेच टैग इंजेक्ट करता है. इसे DevTools में एलिमेंट पैनल में देखा जा सकता है.
नेटवर्क पैनल में अनुरोधों को देखकर यह भी पता चलता है कि अन्य सभी संसाधनों के अनुरोध किए जाने के बाद, इस चंक को कम प्राथमिकता के साथ फ़ेच किया जाता है.
हालांकि, इस्तेमाल के इस उदाहरण के लिए प्रीफ़ेच ज़्यादा सही है, लेकिन webpack ऐसे हिस्सों को भी पहले से लोड करने में मदद करता है जिन्हें डाइनैमिक तरीके से इंपोर्ट किया जाता है.
import(/* webpackPreload: true */ 'module')
नतीजा
इस कोडलैब की मदद से, आपको इस बारे में अच्छी तरह से पता होना चाहिए कि कुछ ऐसेट को पहले से लोड करने या प्रीफ़ेच करने से, आपकी साइट पर उपयोगकर्ता अनुभव को कैसे बेहतर बनाया जा सकता है. यह बताना ज़रूरी है कि इन तकनीकों का इस्तेमाल हर संसाधन के लिए नहीं किया जाना चाहिए. साथ ही, इनका गलत तरीके से इस्तेमाल करने से परफ़ॉर्मेंस पर असर पड़ सकता है. सबसे अच्छे नतीजे, सिर्फ़ चुनिंदा कॉन्टेंट को प्रीलोड या प्रीफ़ेच करके मिलते हैं.
खास जानकारी:
- उन संसाधनों के लिए पहले से लोड करने की सुविधा का इस्तेमाल करें जो देर से खोजे गए हैं, लेकिन मौजूदा पेज के लिए ज़रूरी हैं.
- आने वाले समय में नेविगेशन रूट या उपयोगकर्ता की कार्रवाई के लिए ज़रूरी संसाधनों के लिए, प्रीफ़ेच का इस्तेमाल करें.
फ़िलहाल, सभी ब्राउज़र पर प्रीलोड और प्रीफ़ेच, दोनों की सुविधा काम नहीं करती. इसका मतलब है कि आपके ऐप्लिकेशन के सभी उपयोगकर्ताओं को परफ़ॉर्मेंस में सुधार नहीं दिख सकता.
अगर आपको इस बारे में ज़्यादा जानकारी चाहिए कि प्रीलोड करने और पहले से लोड करने की सुविधा से आपके वेब पेज पर क्या असर पड़ सकता है, तो ये लेख पढ़ें: