ज़रूरी सीएसएस एक्सट्रैक्ट करें

सीएसएस की अहम तकनीक की मदद से, रेंडर होने में लगने वाले समय को बेहतर बनाने का तरीका जानें.

मिलिका मिहाजलिया
मिलिका मिहाजलिया

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

एक इलस्ट्रेशन, जिसमें लैपटॉप और मोबाइल डिवाइस की स्क्रीन के किनारों पर वेब पेज दिख रहे हैं

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

एचटीएमएल फ़ाइल, जिसके सिर में ज़रूरी सीएसएस इनलाइन है
इनलाइन क्रिटिकल सीएसएस

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

फ़िल्मस्ट्रिप व्यू की तुलना, किसी 3G कनेक्शन पर रेंडर-ब्लॉक करने वाले सीएसएस (सबसे ऊपर) और इनलाइन क्रिटिकल सीएसएस (नीचे) वाले पेज को लोड करने की तुलना. सबसे लोकप्रिय फ़िल्मस्ट्रिप में कॉन्टेंट दिखाने से पहले, छह खाली फ़्रेम दिखाए जाते हैं. नीचे की फ़िल्मस्ट्रिप में, पहले फ़्रेम में काम का कॉन्टेंट दिखता है.
किसी 3G कनेक्शन पर, रेंडर करने वाले सीएसएस (सबसे ऊपर) वाले पेज और इनलाइन क्रिटिकल सीएसएस (नीचे) वाले एक ही पेज को लोड करने की तुलना

अगर आपका फ़र्स्ट कॉन्टेंटफ़ुल पेंट (एफ़सीपी) खराब है और आपको लाइटहाउस ऑडिट में "रेंडर ब्लॉक करने वाले रिसॉर्स को हटाने" का अवसर दिखता है, तो बेहतर होगा कि आप ज़रूरी सीएसएस को शामिल करें.

लाइटहाउस ऑडिट, &#39;रेंडर ब्लॉक करने वाले रिसॉर्स को हटाएं&#39; या &#39;इस्तेमाल नहीं किए गए सीएसएस को रोकें&#39;

पहले रेंडर करने के लिए राउंडट्रिप की संख्या को कम करने के लिए, पेज के ऊपरी हिस्से पर मौजूद कॉन्टेंट को 14 केबी (कंप्रेस्ड) के अंदर रखें.

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

टूल की खास जानकारी

ऐसे कई बेहतरीन टूल हैं जो किसी पेज के लिए, अपने-आप ज़रूरी सीएसएस तय कर सकते हैं. यह एक अच्छी खबर है, क्योंकि इसे मैन्युअल तरीके से करना एक मुश्किल प्रक्रिया हो सकती है. व्यूपोर्ट में हर एलिमेंट पर लागू होने वाली स्टाइल को तय करने के लिए, पूरे डीओएम का विश्लेषण करना ज़रूरी होता है.

अहम

अहम एक्सट्रैक्ट करने, छोटा करने, और वेबपेज के ऊपरी हिस्से में मौजूद सीएसएस में इनलाइन का इस्तेमाल होता है. यह npm मॉड्यूल के तौर पर उपलब्ध है. इसका इस्तेमाल Gulp (सीधे तौर पर) या Grunt (plugin के तौर पर) के साथ किया जा सकता है. साथ ही, इसमें एक वेबपैक प्लगिन भी है.

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

criticalCSS

CriticalCSS एक और npm मॉड्यूल है, जो फ़ोल्ड के ऊपर वाले सीएसएस को एक्सट्रैक्ट करता है. यह सीएलआई के तौर पर भी उपलब्ध है.

इसमें ज़रूरी सीएसएस को इनलाइन और छोटा करने के विकल्प नहीं हैं. हालांकि, यह आपको ऐसे नियमों को ज़बरदस्ती शामिल करने की सुविधा देता है जो असल में ज़रूरी सीएसएस से जुड़े नहीं हैं. साथ ही, यह आपको @font-face की जानकारी को शामिल करने के लिए ज़्यादा कंट्रोल देता है.

पेंटहाउस

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

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