راهنمای فنی رفع خطای CLS: از تشخیص تا صفر کردن Cumulative Layout Shift

برای یک مدیر بازاریابی فنی مانند «سارا»، هیچ چیز آزاردهندهتر از دادهای نیست که نشان دهد کاربران به دلیل یک خطای فنی قابل پیشگیری، تجربهای ناخوشایند داشتهاند. همه ما این را تجربه کردهایم: قصد کلیک بر روی یک دکمه را دارید و در آخرین لحظه، یک بنر تبلیغاتی بارگذاری میشود، صفحه به پایین میپرد و شما روی لینک اشتباهی کلیک میکنید. این پدیده «جابجایی چیدمان» (Layout Shift) نام دارد و متریک فنی سنجش آن، Cumulative Layout Shift (CLS) است.
آنچه در این مقاله میخوانید
- راهنمای فنی رفع خطای CLS: از تشخیص تا صفر کردن Cumulative Layout Shift
- CLS چیست؟ (Cumulative Layout Shift) به زبان فنی
- چرا بهینهسازی CLS حیاتیترین بخش تجربه کاربری است؟
- تشریح فنی: دلایل اصلی ایجاد CLS (Layout Shift) و نحوه شناسایی آنها
- ۱. تصاویر بدون ابعاد (Images Without Dimensions)
- ۲. فونتهای وب و پدیده FOIT/FOUT
- ۳. محتوای داینامیک، تبلیغات و Iframeها
- ۴. انیمیشنها و ترنزیشنهای مبتنی بر CSS (Non-Composited Animations)
- چگونه CLS را اندازهگیری و عناصر مشکلساز را پیدا کنیم؟
- چک لیست گام به گام: فرآیند فنی رفع خطای CLS (صفر کردن CLS)
- گام اول: تخصیص فضا برای تصاویر (حل مشکل تصاویر بدون ابعاد)
- گام دوم: مدیریت فونتهای وب (جلوگیری از FOIT/FOUT)
- گام سوم: رزرو فضا برای محتوای داینامیک (تبلیغات و Iframeها)
- گام چهارم: استفاده از انیمیشنهای بهینه (Compositor-Friendly)
- گام پنجم: نظارت مستمر (Monitoring)
- نتیجهگیری: رفع خطای CLS به مثابه یک تعهد به UX
این راهنما یک دستورالعمل فنی عمیق برای درک، تشخیص و رفع خطای CLS است. به عنوان یکی از سه ستون اصلی بهینهسازی Core Web Vitals، تسلط بر رفع خطای CLS یک مزیت رقابتی غیرقابل انکار است. نادیده گرفتن آن نه تنها به رتبه سئوی شما آسیب میزند، بلکه مستقیماً اعتماد کاربر را از بین میبرد و نرخ تبدیل را کاهش میدهد.
CLS چیست؟ (Cumulative Layout Shift) به زبان فنی
CLS چیست؟ به زبان ساده، Cumulative Layout Shift (CLS) یک متریک کاربر-محور از مجموعه Core Web Vitals است که میزان «ناپایداری بصری» (Visual Stability) یک صفحه را اندازهگیری میکند. برخلاف LCP که سرعت بارگذاری را میسنجد، CLS مجموع تمام جابجاییهای غیرمنتظره چیدمان را که در طول *کل* عمر بازدید کاربر از صفحه رخ میدهد، اندازهگیری میکند.
یک «جابجایی چیدمان» (Layout Shift) زمانی رخ میدهد که یک عنصر قابل مشاهده در صفحه، موقعیت خود را از یک فریم رندر شده به فریم بعدی تغییر دهد. طبق تعریف گوگل، امتیاز CLS بر اساس دو فاکتور محاسبه میشود: «کسر ضربه» (Impact Fraction – چقدر از صفحه تحت تأثیر قرار گرفت) و «کسر فاصله» (Distance Fraction – عنصر چقدر جابجا شد). درک این محاسبه فنی، اولین قدم برای رفع خطای CLS است.
امتیازدهی CLS به صورت زیر است:
- خوب (Good): امتیاز CLS زیر ۰.۱
- نیاز به بهبود (Needs Improvement): بین ۰.۱ تا ۰.۲۵
- ضعیف (Poor): بالای ۰.۲۵
هدف ما به عنوان متخصصان فنی، رساندن این عدد به نزدیکترین حالت ممکن به صفر است. در کنار LCP و متریک INP (که جایگزین FID شده)، بهینه سازی CLS برای موفقیت در Core Web Vitals حیاتی است.
چرا بهینهسازی CLS حیاتیترین بخش تجربه کاربری است؟
«CLS چیست؟» فقط یک متریک سئو نیست؛ این مستقیمترین شاخص فنی برای سنجش یک طراحی UI/UX ضعیف است. وقتی عناصر صفحه به طور غیرمنتظره جابجا میشوند، نه تنها باعث سردرگمی کاربر میشوند، بلکه مستقیماً «اعتماد» او را به رابط کاربری شما از بین میبرند. این نقض صریح اصول UX برای Core Web Vitals است.
برای «سارا»، این موضوع باید به زبان کسبوکار ترجمه شود: CLS بالا منجر به کلیکهای اشتباه، افزایش نرخ پرش (Bounce Rate) در صفحات محصول، و کاهش شدید نرخ تبدیل در فرمهای ثبتنام یا پرداخت میشود. بنابراین، رفع خطای CLS مستقیماً بر نرخ تبدیل و ROI بازاریابی تأثیر میگذارد.
تشریح فنی: دلایل اصلی ایجاد CLS (Layout Shift) و نحوه شناسایی آنها
قبل از اینکه بتوانیم مشکلی را حل کنیم، باید علت ریشهای آن را درک کنیم. رفع خطای CLS با تشخیص دقیق شروع میشود. خوشبختانه، دلایل ایجاد Cumulative Layout Shift معمولاً به چند مقصر اصلی محدود میشوند. شناسایی آنها برای رفع خطای CLS ضروری است.

۱. تصاویر بدون ابعاد (Images Without Dimensions)
این رایجترین و بزرگترین دلیل ایجاد Layout Shift است. اولین مظنون در هر فرآیند رفع خطای CLS، تصاویر بدون ابعاد هستند. فرآیند به این شکل است: مرورگر شروع به رندر کردن HTML و متن میکند. سپس، فایل تصویر (که دانلود آن زمان میبرد) بارگذاری میشود. از آنجایی که مرورگر *نمیدانسته* چقدر فضا باید برای آن تصویر رزرو کند، مجبور میشود تمام متنی را که قبلاً رندر کرده، به پایین هل دهد تا جا برای تصویر باز شود. این یک جابجایی عظیم ایجاد میکند.
این مشکل زمانی تشدید میشود که از سیستمهای مدیریت محتوا (CMS) استفاده میکنید و ویرایشگرها به سادگی تصاویر را بدون تعریف صریح `width` و `height` در تگ `` درج میکنند. این موضوع مستقیماً به فرآیند بهینه سازی تصاویر برای CWV گره خورده است.
۲. فونتهای وب و پدیده FOIT/FOUT
دومین مقصر رایج، نحوه بارگذاری فونتهای سفارشی وب (Web Fonts) است. فرآیند رفع خطای CLS برای فونتها نیاز به درک دو مفهوم FOIT/FOUT دارد:
- FOIT (Flash of Invisible Text): مرورگر منتظر میماند تا فونت سفارشی دانلود شود. در این مدت، متن نامرئی است. به محض دانلود فونت، متن ظاهر میشود. اگر این فرآیند باعث تغییر در چیدمان شود (که معمولاً میشود)، CLS رخ میدهد.
- FOUT (Flash of Unstyled Text): مرورگر ابتدا متن را با یک فونت سیستمی (Fallback) نمایش میدهد. سپس، فونت سفارشی دانلود شده و جایگزین فونت سیستمی میشود. از آنجایی که فونت سفارشی احتمالاً ابعاد، ارتفاع خط و فاصله حروف متفاوتی نسبت به فونت سیستمی دارد، این «جایگزینی» باعث جابجایی متن و ایجاد Layout Shift میشود.
۳. محتوای داینامیک، تبلیغات و Iframeها
این یکی از چالشبرانگیزترین بخشهای رفع خطای CLS است. هر عنصری که *پس* از رندر اولیه به صفحه تزریق (Inject) میشود، پتانسیل ایجاد CLS را دارد. مقصران اصلی عبارتند از:
- تبلیغات (Ads): اسکریپتهای تبلیغاتی (مانند AdSense) اغلب یک کانتینر خالی را رها میکنند و سپس یک بنر با اندازه غیرمنتظره را در آن بارگذاری میکنند و تمام محتوای زیرین را به پایین میرانند.
- Iframeها: ویدئوهای Embed شده (مانند YouTube) یا ویجتهای شبکههای اجتماعی که ابعاد مشخصی ندارند.
- محتوای داینامیک: بنرهای «کوکی»، اعلانهای «به خبرنامه ما بپیوندید» یا ویجتهای «مطالب مرتبط» که به صورت ناگهانی در بالای صفحه یا بین محتوا ظاهر میشوند.
۴. انیمیشنها و ترنزیشنهای مبتنی بر CSS (Non-Composited Animations)
این یک خطای فنی ظریف است. برخی از انیمیشنهای CSS مرورگر را مجبور به محاسبه مجدد چیدمان (Re-layout) در هر فریم میکنند. اگر شما ویژگیهایی مانند `margin`, `padding`, `top` یا `height` را انیمیت کنید، در حال ایجاد Layout Shift هستید. رفع خطای CLS در اینجا به معنای استفاده از ویژگیهای بهینه CSS است.
چگونه CLS را اندازهگیری و عناصر مشکلساز را پیدا کنیم؟
رفع خطای CLS با ابزار مناسب آغاز میشود. این ابزارها برای رفع خطای CLS حیاتی هستند:
- دادههای میدانی (Field Data – RUM):
- Google Search Console: گزارش Core Web Vitals به شما URLهایی را نشان میدهد که کاربران واقعی در آنها CLS ضعیف را تجربه میکنند.
- PageSpeed Insights (PSI): بخش “Real User Data” (Field Data).
- دادههای آزمایشگاهی (Lab Data – Synthetic):
- Lighthouse (در Chrome DevTools): امتیاز CLS را در بارگذاری شبیهسازی شده نشان میدهد.
- WebPageTest: فیلم دقیقی از نحوه بارگذاری و جابجایی صفحه ارائه میدهد.
- ابزار دیباگینگ (Debugging Tool):
- Chrome DevTools: به `More Tools` > `Rendering` بروید و تیک `Layout Shift Regions` را بزنید. اکنون، هر زمان که جابجایی رخ دهد، آن ناحیه به رنگ آبی هایلایت میشود و میتوانید دقیقاً عنصر مقصر را شناسایی کنید.
چک لیست گام به گام: فرآیند فنی رفع خطای CLS (صفر کردن CLS)
اکنون که میدانیم CLS چیست و دلایل آن کدامند، زمان اجرای چکلیست فنی برای رفع خطای CLS است. هدف ما رساندن این متریک به نزدیک صفر است.

گام اول: تخصیص فضا برای تصاویر (حل مشکل تصاویر بدون ابعاد)
این مهمترین گام در بهینه سازی CLS است. شما باید به مرورگر بگویید که چقدر فضا را *قبل* از دانلود تصویر، رزرو کند.
- راه حل کلاسیک: همیشه از اتریبیوتهای `width` و `height` در تگهای “ خود استفاده کنید.
<img src="image.jpg" width="640" height="360" alt="...">
حتی اگر با CSS اندازهها را تغییر دهید، مرورگر از این دو اتریبیوت برای محاسبه «نسبت ابعاد» (Aspect Ratio) و رزرو فضا استفاده میکند. - راه حل مدرن (CSS Aspect Ratio): برای تصاویر بدون ابعاد در طراحیهای ریسپانسیو، اتکا به `height: auto` باعث CLS میشود. راهحل مدرن، استفاده از ویژگی CSS `aspect-ratio` است.
نکته فنی: استفاده از CSS aspect-ratio
به جای تنظیم `height: auto`، میتوانید به سادگی به مرورگر بگویید نسبت ابعاد را حفظ کند. با تنظیم `img { width: 100%; height: auto; aspect-ratio: 16 / 9; }` (یا هر نسبت دیگری مانند
width / height)، مرورگر *قبل* از بارگذاری تصویر، فضای صحیح را بر اساس عرض ۱۰۰٪ و نسبت ابعاد داده شده، رزرو میکند. این راهحل مدرن، رفع خطای CLS را در صفحات ریسپانسیو بسیار سادهتر میکند.
این فرآیند بخشی جداییناپذیر از بهینه سازی تصاویر برای CWV است.
گام دوم: مدیریت فونتهای وب (جلوگیری از FOIT/FOUT)
رفع خطای CLS ناشی از FOIT/FOUT نیازمند مدیریت دقیق بارگذاری فونت است.
- استفاده از `font-display: swap` (حیاتی): این دستور CSS را به تعریف
@font-faceخود اضافه کنید. این کار FOIT را حذف میکند و FOUT را فعال میکند (متن با فونت سیستمی نمایش داده میشود تا زمانی که فونت سفارشی آماده شود). - به حداقل رساندن FOUT: `swap` به تنهایی میتواند باعث CLS شود (اگر فونت سیستمی و فونت سفارشی تفاوت زیادی داشته باشند). برای کاهش CLS ناشی از FOUT، سعی کنید فونت سیستمی جایگزین (Fallback) را طوری انتخاب کنید که از نظر اندازه و ارتفاع خط، بسیار شبیه به فونت سفارشی شما باشد. (ابزارهایی برای این تطبیق وجود دارد).
- Preload کردن فونتهای حیاتی: اگر فونتی برای محتوای بالای صفحه (Above-the-fold) حیاتی است، از `<link rel=”preload” href=”/font.woff2″ as=”font” type=”font/woff2″ crossorigin>` در
<head>استفاده کنید. این کار باعث میشود فونت زودتر دانلود شود و زمان «جایگزینی» (swap) به حداقل برسد. این یک مصالحه کلیدی در فرآیند رفع خطای CLS است.
گام سوم: رزرو فضا برای محتوای داینامیک (تبلیغات و Iframeها)
قانون طلایی رفع خطای CLS این است: *همیشه* برای محتوایی که بعداً بارگذاری میشود، فضا رزرو کنید. هرگز اجازه ندهید یک کانتینر با ارتفاع صفر (Collapse) ایجاد شود و سپس به صورت ناگهانی باز شود.
- برای تبلیغات: قبل از اجرای اسکریپت تبلیغات، به `div` نگهدارنده آن، یک `min-height` مشخص (بر اساس بزرگترین سایز تبلیغی که ممکن است نمایش داده شود) بدهید. اگر جایگاه تبلیغ ۷۲۸x۹۰ است، `div` نگهدارنده باید `min-height: 90px;` داشته باشد.
- برای Iframeها (مانند ویدئو): از ترفند “CSS aspect-ratio box” برای رزرو فضا استفاده کنید. این تکنیک یک کانتینر والد با `aspect-ratio` (مثلاً ۱۶:۹) ایجاد میکند که iframe به صورت `position: absolute` درون آن قرار میگیرد.
بدون رزرو فضا، رفع خطای CLS برای محتوای داینامیک غیرممکن است.
گام چهارم: استفاده از انیمیشنهای بهینه (Compositor-Friendly)
این یک راهحل فنی ساده برای رفع خطای CLS ناشی از انیمیشن است: *هرگز* ویژگیهای CSS که بر چیدمان (Layout) تأثیر میگذارند را انیمیت نکنید (مانند `height`, `width`, `margin`, `padding`, `top`, `left`).
تکنیک فنی: انیمیشنهای Transform و Opacity
به جای انیمیت کردن `margin-left` برای حرکت دادن یک عنصر، از `transform: translateX()` استفاده کنید. به جای انیمیت کردن `height` برای باز شدن یک منو، از `transform: scaleY()` استفاده کنید. انیمیشنهای مبتنی بر `transform` و `opacity` توسط پردازنده گرافیکی (GPU) و در یک رشته جداگانه (Compositor Thread) مدیریت میشوند و باعث محاسبه مجدد چیدمان (Re-layout) و در نتیجه Layout Shift نمیشوند. این یک تکنیک پیشرفته اما مهم در رفع خطای CLS است.
گام پنجم: نظارت مستمر (Monitoring)
رفع خطای CLS یک پروژه یکباره نیست؛ این یک فرآیند نگهداری مداوم است. یک ویژگی جدید، یک افزونه وردپرس یا یک جایگاه تبلیغاتی جدید میتواند امتیاز Cumulative Layout Shift شما را که به سختی به صفر رساندهاید، دوباره خراب کند. به طور مداوم گزارش Core Web Vitals در GSC را برای شناسایی رگرسیونها (Regression) بررسی کنید.
نتیجهگیری: رفع خطای CLS به مثابه یک تعهد به UX
برای «سارا» و تیم فنی او، رفع خطای CLS فقط یک بهینهسازی فنی نیست، بلکه یک تعهد به طراحی UI/UX باکیفیت و احترام به کاربر است. در حالی که LCP بر «سرعت» تمرکز دارد، بهینه سازی CLS بر «آرامش» و «قابلیت اطمینان» رابط کاربری تمرکز دارد.
دلایل اصلی (تصاویر بدون ابعاد، FOIT/FOUT، تبلیغات) کاملاً قابل شناسایی و قابل حل هستند. راهحل در یک کلمه خلاصه میشود: «رزرو فضا». با اجرای تکنیکهای فنی مانند اتریبیوتهای ابعاد، `aspect-ratio`، `font-display: swap` و رزرو فضا برای تبلیغات، میتوانید امتیاز CLS خود را به نزدیکی صفر برسانید. امتیاز CLS پایین (نزدیک به صفر) نتیجه مستقیم یک فرآیند رفع خطای CLS موفق است. تیم «آدرینالیز» این نقشه راه کامل رفع خطای CLS را برای «سارا» آماده کرده است.

