Cumulative Layout Shift (CLS)

ब्राउज़र सहायता

  • 77
  • 79
  • x
  • x

सोर्स

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

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

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

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

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

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

सीएलएस क्या है?

सीएलएस, किसी पेज की पूरी लाइफ़साइकल के दौरान होने वाले हर अनचाहे लेआउट शिफ़्ट के लिए, लेआउट शिफ़्ट स्कोर के सबसे बड़े बर्स्ट का पैमाना है.

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

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

सबसे बड़ा बर्स्ट वह सेशन विंडो है जिसमें उस विंडो में मौजूद सभी लेआउट शिफ़्ट का सबसे ज़्यादा स्कोर होता है.

सेशन विंडो का उदाहरण. नीले बार, हर लेआउट शिफ़्ट का स्कोर दिखाते हैं.

अच्छा सीएलएस स्कोर क्या होता है?

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

सीएलएस की अच्छी वैल्यू 0.1 या उससे कम है, खराब वैल्यू 0.25 से ज़्यादा है, और सुधार की ज़रूरत के बीच कुछ भी है
सीएलएस की अच्छी वैल्यू 0.1 या इससे कम है. खराब वैल्यू 0.25 से ज़्यादा हैं.

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

लेआउट शिफ़्ट की जानकारी

लेआउट शिफ़्ट, Layout Instability API से तय किए जाते हैं. यह किसी भी समय, layout-shift एंट्री को रिपोर्ट करता है. ऐसा तब होता है, जब व्यूपोर्ट में दिखने वाला कोई एलिमेंट, दो फ़्रेम के बीच अपनी शुरुआती पोज़िशन (उदाहरण के लिए, डिफ़ॉल्ट राइटिंग मोड) में सबसे ऊपर और बाईं ओर बदलता है. ऐसे एलिमेंट को असुरक्षित एलिमेंट माना जाता है.

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

लेआउट शिफ़्ट स्कोर

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

layout shift score = impact fraction * distance fraction

इंपैक्ट फ़्रैक्शन

असर वाले फ़्रैक्शन से यह पता चलता है कि असुरक्षित एलिमेंट, दो फ़्रेम के बीच के व्यूपोर्ट एरिया पर कैसे असर डालते हैं.

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

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

पिछली इमेज में, एक ऐसा एलिमेंट है जो एक फ़्रेम में, व्यूपोर्ट का आधा हिस्सा घेर लेता है. फिर, अगले फ़्रेम में एलिमेंट, व्यूपोर्ट की ऊंचाई के 25% तक नीचे शिफ़्ट हो जाता है. लाल रंग का बिंदु वाला रेक्टैंगल, दोनों फ़्रेम में एलिमेंट के दिखने वाले एरिया को एक साथ दिखाने के बारे में बताता है. इस मामले में यह एरिया, पूरे व्यूपोर्ट का 75% है, इसलिए इसका इफ़ेक्ट फ़्रैक्शन 0.75 है.

दूरी का अंश

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

एक अस्थिर एलिमेंट के साथ दूरी भिन्न का उदाहरण
दूरी का अंश यह मापता है कि व्यूपोर्ट पर कोई एलिमेंट कितनी दूर तक मूव किया गया है.

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

इसलिए, इस उदाहरण में इफ़ेक्ट फ़्रैक्शन 0.75 है और डिस्टेंस फ़्रैक्शन 0.25 है, इसलिए लेआउट शिफ़्ट स्कोर 0.75 * 0.25 = 0.1875 है.

उदाहरण

अगले उदाहरण में दिखाया गया है कि किसी मौजूदा एलिमेंट में कॉन्टेंट जोड़ने से, लेआउट शिफ़्ट स्कोर पर क्या असर पड़ता है:

एक से ज़्यादा स्टेबल और _unstable एलिमेंट के साथ लेआउट शिफ़्ट का उदाहरण
स्लेटी रंग के बॉक्स के नीचे बटन जोड़ने से हरे बॉक्स नीचे की ओर धकेल जाते हैं और व्यूपोर्ट से बाहर निकल जाते हैं.

इस उदाहरण में, स्लेटी रंग के बॉक्स का साइज़ बदल जाता है, लेकिन इसके शुरू होने की जगह में कोई बदलाव नहीं होता. इसलिए, यह असुरक्षित एलिमेंट नहीं है.

"क्लिक मी!" बटन पहले डीओएम में नहीं था. इसलिए, इसकी स्टार्ट पोज़िशन भी नहीं बदलती.

हालांकि, हरे रंग के बॉक्स की शुरुआती स्थिति बदल जाती है, लेकिन इसे कुछ हद तक व्यूपोर्ट से बाहर ले जाया गया है, इसलिए असर वाले फ़्रैक्शन का हिसाब लगाते समय, दिखाई न देने वाली जगह को शामिल नहीं किया जाता. दोनों फ़्रेम (लाल, बिंदुदार आयत) में हरे बॉक्स के लिए दिखने वाले इलाकों का योग, पहले फ़्रेम में हरे बॉक्स के क्षेत्रफल के बराबर ही होता है—व्यूपोर्ट का 50%. इफ़ेक्ट फ़्रैक्शन 0.5 है.

दूरी का अंश बैंगनी तीर से दिखाया गया है. हरे रंग के बॉक्स को व्यूपोर्ट के करीब 14% नीचे ले जाया गया है, इसलिए दूरी का अंश 0.14 है.

लेआउट शिफ़्ट स्कोर 0.5 x 0.14 = 0.07 है.

इस उदाहरण में दिखाया गया है कि कई अस्थिर एलिमेंट, किसी पेज के लेआउट शिफ़्ट स्कोर पर कैसे असर डालते हैं:

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

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

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

फिर से, लाल, बिंदुदार आयत इन तीन असुरक्षित तत्वों' के संयोजन को दिखाते हैं क्षेत्रों के पहले और बाद में, जो इस मामले में व्यूपोर्ट के क्षेत्र का करीब 60% है (0.60 का असर आंशिक).

ऐरो उन दूरियों को दिखाते हैं जिनमें अनिश्चित एलिमेंट अपनी शुरुआती जगह से चले गए हैं. "ज़ीब्रा" एलिमेंट को नीले ऐरो से दिखाया गया है. यह व्यूपोर्ट की ऊंचाई के करीब 30% तक सबसे ज़्यादा खिसक गया है. इससे इस उदाहरण में दूरी का अंश 0.3 हो जाता है.

लेआउट शिफ़्ट स्कोर 0.60 x 0.3 = 0.18 है.

अनुमानित बनाम अनचाहे लेआउट शिफ़्ट

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

उपयोगकर्ता की ओर से शुरू किए गए लेआउट शिफ़्ट

उपयोगकर्ता इंटरैक्शन के जवाब में होने वाले लेआउट शिफ़्ट (जैसे, किसी लिंक पर क्लिक करना या टैप करना, बटन दबाना या खोज बॉक्स में टाइप करना) आम तौर पर तब तक ठीक होते हैं, जब तक शिफ़्ट उस इंटरैक्शन के काफ़ी करीब हो जिससे उपयोगकर्ता को साफ़ तौर पर जानकारी मिल रही हो.

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

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

ऐनिमेशन और ट्रांज़िशन

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

prefers-reduced-motion ब्राउज़र की सेटिंग का पालन ज़रूर करें. ऐसा इसलिए, क्योंकि ऐनिमेशन की वजह से, साइट पर आने वाले कुछ लोगों को खराब असर या ध्यान खींचने में समस्या हो सकती है.

सीएसएस transform प्रॉपर्टी की मदद से, लेआउट शिफ़्ट ट्रिगर किए बिना एलिमेंट ऐनिमेट किए जा सकते हैं:

  • height और width प्रॉपर्टी को बदलने के बजाय, transform: scale() का इस्तेमाल करें.
  • एलिमेंट को इधर-उधर ले जाने के लिए, top, right, bottom या left प्रॉपर्टी को बदलने से बचें. इसके बजाय, transform: translate() का इस्तेमाल करें.

सीएलएस को मापने का तरीका

सीएलएस को लैब में या फ़ील्ड में मापा जा सकता है. यह इन टूल में उपलब्ध है:

फ़ील्ड टूल

लैब टूल

JavaScript में लेआउट शिफ़्ट मेज़र करना

JavaScript में लेआउट शिफ़्ट मेज़र करने के लिए, Layout Instability API का इस्तेमाल करें.

नीचे दिए गए उदाहरण में, कंसोल में layout-shift एंट्री को लॉग करने के लिए, PerformanceObserver बनाने का तरीका बताया गया है:

new PerformanceObserver((entryList) => {
  for (const entry of entryList.getEntries()) {
    console.log('Layout shift:', entry);
  }
}).observe({type: 'layout-shift', buffered: true});

JavaScript में सीएलएस मेज़र करना

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

ज़्यादातर मामलों में, पेज के अनलोड होने के समय की मौजूदा सीएलएस वैल्यू, उस पेज के लिए आखिरी सीएलएस वैल्यू होती है. हालांकि, अगले सेक्शन में कुछ अहम अपवाद भी हैं. वेब एपीआई की सीमाओं के अंदर, ज़्यादा से ज़्यादा इन चीज़ों के लिए, web vitals JavaScript लाइब्रेरी खाते का इस्तेमाल किया जाता है.

मेट्रिक और एपीआई के बीच अंतर

  • अगर किसी पेज को बैकग्राउंड में लोड किया जाता है या ब्राउज़र किसी कॉन्टेंट को पेंट करने से पहले, उसे बैकग्राउंड में लोड किया जाता है, तो सीएलएस वैल्यू की रिपोर्ट नहीं होनी चाहिए.
  • अगर किसी पेज को बैक/फ़ॉरवर्ड कैश मेमोरी से वापस लाया जाता है, तो उसकी सीएलएस वैल्यू शून्य पर रीसेट होनी चाहिए. ऐसा इसलिए, क्योंकि उपयोगकर्ता इसे एक अलग पेज विज़िट के तौर पर देखते हैं.
  • एपीआई, iframe में होने वाले बदलावों के लिए layout-shift एंट्री को रिपोर्ट नहीं करता. हालांकि, मेट्रिक ऐसा करती है, क्योंकि वे पेज के उपयोगकर्ता अनुभव का हिस्सा होती हैं. इससे CrUX और RUM के बीच के अंतर को दिखाया जा सकता है. सीएलएस को सही तरीके से मापने के लिए, आपको उन पर ध्यान देना चाहिए. सब-फ़्रेम, एपीआई का इस्तेमाल करके एग्रीगेशन के लिए अपनी layout-shift एंट्री को पैरंट फ़्रेम में रिपोर्ट कर सकते हैं.

इन अपवादों के अलावा, सीएलएस में कुछ और दिक्कतें होती हैं, क्योंकि यह किसी पेज के पूरे लाइफ़स्पैन का आकलन करता है:

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

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

इन सभी मामलों को खुद याद रखने और उनसे निपटने के बजाय, डेवलपर सीएलएस को मापने के लिए web-vitals JavaScript लाइब्रेरी का इस्तेमाल कर सकते हैं. सीएलएस, iframe केस को छोड़कर ऊपर बताई गई सभी चीज़ों के लिए ज़िम्मेदार है:

import {onCLS} from 'web-vitals';

// Measure and log CLS in all situations
// where it needs to be reported.
onCLS(console.log);

सीएलएस को बेहतर बनाने का तरीका

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

अन्य संसाधन

बदलावों का लॉग

कभी-कभी, मेट्रिक को मापने के लिए इस्तेमाल किए जाने वाले एपीआई में गड़बड़ियां मिलती हैं. कभी-कभी खुद मेट्रिक की परिभाषा में गड़बड़ियां मिलती हैं. इस वजह से, कभी-कभी बदलाव करने पड़ते हैं. ये बदलाव आपकी इंटरनल रिपोर्ट और डैशबोर्ड में सुधार या रिग्रेशन के तौर पर दिख सकते हैं.

इसे मैनेज करने में आपकी मदद करने के लिए, इन मेट्रिक को लागू करने या उनकी परिभाषा करने में किए जाने वाले सभी बदलाव, इस बदलाव लॉग में दिखेंगे.

अगर आपको इन मेट्रिक के बारे में कोई सुझाव/राय देनी है या शिकायत करनी है, तो web-fitals-feedback Google ग्रुप पर जाएं.