به صورت دستی فعل و انفعالات کند را در آزمایشگاه تشخیص دهید

بیاموزید که چگونه داده‌های میدانی خود را به آزمایشگاه ببرید تا از طریق آزمایش دستی، علل ایجاد کنش‌های کند را شناسایی کنید.

بخش چالش برانگیز بهینه سازی Interaction to Next Paint (INP) این است که بفهمیم چه چیزی باعث INP ضعیف شده است. دلایل بالقوه زیادی وجود دارد، مانند اسکریپت های شخص ثالث که بسیاری از وظایف را در رشته اصلی برنامه ریزی می کنند، اندازه های بزرگ DOM ، تماس های رویداد گران قیمت، و سایر مجرمان.

بهبود INP می تواند دشوار باشد. برای شروع، باید بدانید که کدام فعل و انفعالات مسئول INP صفحه هستند. اگر نمی‌دانید کدام تعامل در وب‌سایت شما از دیدگاه کاربر واقعی کندتر است، جستجوی تعاملات آهسته در زمینه را بخوانید. هنگامی که داده‌های میدانی برای راهنمایی دارید، می‌توانید آن فعل و انفعالات خاص را به صورت دستی در ابزارهای آزمایشگاهی آزمایش کنید تا بفهمید چرا این تعاملات کند هستند.

اگر داده های میدانی نداشته باشید چه؟

داشتن داده‌های میدانی حیاتی است، زیرا در زمان زیادی صرفه‌جویی می‌کند تا بفهمید کدام تعامل‌ها باید بهینه شوند. اگرچه ممکن است در موقعیتی باشید که داده های میدانی ندارید. اگر شرایط شما را توصیف می‌کند، هنوز هم می‌توانید تعاملاتی برای بهبود پیدا کنید، اگرچه کمی تلاش بیشتر و رویکرد متفاوتی نیاز دارد.

زمان مسدود کردن کل (TBT) یک معیار آزمایشگاهی است که پاسخگویی صفحه را در حین بارگذاری ارزیابی می‌کند و به خوبی با INP همبستگی دارد . اگر صفحه شما TBT بالایی دارد، این یک سیگنال بالقوه است که ممکن است صفحه شما در هنگام بارگیری صفحه، پاسخگوی تعاملات کاربر نباشد.

برای تعیین TBT صفحه خود، می توانید از یکی از Lighthouse استفاده کنید. اگر TBT یک صفحه بالا باشد، این احتمال وجود دارد که موضوع اصلی در طول بارگذاری صفحه بیش از حد شلوغ باشد و این می تواند بر میزان پاسخگویی یک صفحه در آن زمان حیاتی در چرخه عمر صفحه تأثیر بگذارد.

برای یافتن تعاملات آهسته پس از بارگیری صفحه، ممکن است به انواع دیگری از داده ها نیاز داشته باشید، مانند جریان های کاربر معمولی که ممکن است قبلاً در تجزیه و تحلیل وب سایت خود شناسایی کرده باشید. برای مثال، اگر روی یک وب‌سایت تجارت الکترونیک کار می‌کنید، یک جریان کاربر معمولی، اقداماتی است که کاربران هنگام افزودن اقلام به سبد خرید آنلاین و بررسی آن انجام می‌دهند.

چه داده های میدانی داشته باشید چه نداشته باشید، گام بعدی این است که به صورت دستی تعاملات آهسته را آزمایش و بازتولید کنید—زیرا تنها زمانی که بتوانید یک تعامل کند را بازتولید کنید می توانید آن را برطرف کنید.

بازتولید فعل و انفعالات آهسته در آزمایشگاه

راه‌های مختلفی وجود دارد که می‌توانید تعاملات آهسته را در آزمایشگاه از طریق آزمایش دستی بازتولید کنید، اما چارچوب زیر می‌توانید امتحان کنید.

ردیابی را ثبت کنید

نمایه‌ساز عملکرد Chrome ابزار توصیه‌شده برای تشخیص و عیب‌یابی تعاملات کند است. برای نمایه کردن یک تعامل در نمایه‌ساز عملکرد Chrome، این مراحل را دنبال کنید:

  1. صفحه ای را که می خواهید آزمایش کنید باز کنید.
  2. Chrome DevTools را باز کنید و به پنل Performance بروید.
  3. برای شروع ردیابی، روی دکمه ضبط در سمت چپ بالای پانل کلیک کنید.
  4. تعامل(هایی) را که می خواهید عیب یابی کنید، انجام دهید.
  5. دوباره روی دکمه Record کلیک کنید تا ردیابی متوقف شود.

وقتی نمایه ساز پر می شود، اولین جایی که باید نگاه کرد باید خلاصه فعالیت در بالای نمایه ساز باشد. خلاصه فعالیت نوارهای قرمز رنگ را در بالا نشان می دهد که در آن وظایف طولانی در ضبط رخ داده است. این به شما امکان می دهد به سرعت روی مناطق مشکل زوم کنید.

خلاصه فعالیت همانطور که در بالای پانل عملکرد Chrome DevTools ظاهر می شود. فعالیت نمایش داده شده بیشتر از جاوا اسکریپت است که باعث یک کار طولانی می شود که با رنگ قرمز در بالای نمودار شعله مشخص شده است.
خلاصه فعالیت در بالای نمایه‌ساز عملکرد Chrome. وظایف طولانی با رنگ قرمز در بالای نمودار شعله فعالیت مشخص شده اند. در این مورد، کار اسکریپت نویسی قابل توجهی مسئول بیشتر کار در کار طولانی بود.

می‌توانید با کشیدن و انتخاب یک منطقه در خلاصه فعالیت، به سرعت روی مناطق مشکل‌دار تمرکز کنید. می‌توانید به‌صورت اختیاری از ویژگی پودر سوخاری در نمایه‌ساز استفاده کنید تا به شما در محدود کردن جدول زمانی و نادیده گرفتن فعالیت‌های نامرتبط کمک کند.

هنگامی که بر محل وقوع تعامل تمرکز کردید، تراک تعاملات به شما کمک می کند تا تعامل و فعالیتی را که در مسیر رشته اصلی در زیر آن رخ داده است، ردیف کنید:

تعاملی که در پانل عملکرد Chrome DevTools به تصویر کشیده شده است. یک مسیر تعامل در بالای مسیر رشته اصلی، مدت زمان یک تعامل را نشان می‌دهد که می‌توان آن را با فعالیت نخ اصلی در زیر آن ردیف کرد.
تعاملی که در نمایه ساز عملکرد در DevTools Chrome نمایه شده است. تراک Interactions مجموعه ای از رویدادها را نشان می دهد که با یک تعامل کلیک مطابقت دارند. ورودی‌های آهنگ تعاملات در سراسر وظایف مسئول ایجاد تعامل است.

می‌توانید جزئیات بیشتری در مورد اینکه کدام بخش از تعامل طولانی‌تر بوده است، با نگه داشتن ماوس روی تکرار در مسیر تعاملات دریافت کنید:

یک راهنمای ابزار برای تعامل همانطور که در پانل عملکرد Chrome DevTools نشان داده شده است. راهنمای ابزار نشان می‌دهد که چقدر زمان در تعامل صرف شده است، از جمله تأخیر ورودی تعامل، مدت زمان پردازش و تأخیر ارائه.
نکته ابزاری که وقتی یک تعامل در مسیر تعاملات پانل عملکرد روی آن قرار می گیرد ظاهر می شود. راهنمای ابزار نشان می دهد که در هر بخش از تعامل چقدر زمان صرف شده است.

بخش راه راه تعامل نشان می دهد که چه مدت زمان تعامل از 200 میلی ثانیه فراتر رفته است، که حد بالای آستانه "خوب" برای INP صفحه است. بخش هایی از تعامل ذکر شده عبارتند از:

  1. تأخیر ورودی - توسط سبیل چپ مشاهده می شود.
  2. مدت زمان پردازش - توسط بلوک جامد بین سبیل چپ و راست تجسم می شود.
  3. تأخیر ارائه - توسط سبیل سمت راست تجسم می شود.

از اینجا، موضوع حفاری عمیق‌تر در مشکلاتی است که باعث کندی تعامل می‌شوند، که بعداً در این راهنما به آن پرداخته می‌شود.

برنامه افزودنی Chrome Web Vitals

نمایه ساز عملکرد رویکرد توصیه شده برای تشخیص تعاملات شناخته شده به کندی است، اما زمانی که ندانید کدام تعاملات مشکل ساز شما هستند، شناسایی تعاملات کند ممکن است زمان ببرد. یکی از رویکردهایی که باید در نظر گرفت استفاده از برنامه افزودنی Chrome Web Vitals است. این برنامه افزودنی می تواند برای آزمایش سریع تعدادی از تعاملات برای یافتن موارد مشکل ساز، قبل از اینکه وارد نمایه ساز عملکرد شوید، استفاده شود.

پس از نصب، برنامه افزودنی Web Vitals داده‌های تعامل را در کنسول DevTools نشان می‌دهد، اگر مراحل زیر را دنبال کنید:

  1. در کروم، روی نماد برنامه‌های افزودنی در سمت راست نوار آدرس کلیک کنید.
  2. پسوند Web Vitals را در منوی کشویی پیدا کنید.
  3. روی نماد سمت راست کلیک کنید تا تنظیمات افزونه باز شود.
  4. روی گزینه ها کلیک کنید.
  5. کادر انتخاب Console Logging را در صفحه‌ی نتیجه فعال کنید و سپس روی Save کلیک کنید.

پس از انجام این مراحل، کنسول را در Chrome DevTools باز کنید و شروع به آزمایش تعاملات مشکوک در یک صفحه کنید. هنگام تعامل، داده‌های تشخیصی در کنسول ظاهر می‌شوند:

نحوه نمایش گزارش‌های INP از افزونه Web Vitals در کنسول Chrome DevTools. گزارش دقیق از جمله اینکه کدام بخش از تعامل طولانی‌ترین زمان را برد، و همچنین داده‌های انتساب دقیق از APIهای عملکرد مختلف در دسترس است.
افزونه Web Vitals می‌تواند داده‌های دقیق را برای تعاملاتی که به INP صفحه در کنسول در ابزار توسعه‌دهنده Chrome کمک می‌کند، ثبت کند.

در حالی که برنامه افزودنی Web Vitals به شناسایی تعاملات آهسته کمک می کند، و برخی جزئیات را برای کمک به اشکال زدایی INP ارائه می دهد، ممکن است همچنان لازم باشد از نمایه ساز عملکرد برای تشخیص تعاملات کند استفاده کنید ، زیرا داده های دقیقی را که برای پیمایش در تولید وب سایت خود نیاز دارید ارائه می کند. کدی برای یافتن دلایل پشت تعاملات کند.

چگونه تشخیص دهیم کدام بخش از یک تعامل کند است

تعاملات شامل سه بخش است: تاخیر ورودی، مدت زمان پردازش و تاخیر ارائه. اینکه چگونه یک تعامل را برای کاهش INP یک صفحه بهینه کنید، بستگی به این دارد که کدام بخش از آن بیشترین زمان را می گیرد.

نحوه شناسایی تاخیرهای ورودی طولانی

تأخیرهای ورودی می تواند تأخیر تعامل بالایی ایجاد کند. تاخیر ورودی اولین بخش از تعامل است. این دوره زمانی است که از زمانی که اقدام کاربر برای اولین بار توسط سیستم عامل دریافت می شود تا زمانی که مرورگر قادر به پردازش اولین تماس کنترل کننده رویداد آن تعامل است.

شناسایی تأخیرهای ورودی در نمایه‌ساز عملکرد Chrome را می‌توان با مکان‌یابی تعامل در مسیر تعاملات انجام داد. طول سبیل سمت چپ بخشی از تاخیر ورودی تعامل را نشان می‌دهد و مقدار دقیق آن را می‌توان در یک راهنمای ابزار با نگه داشتن ماوس روی تعامل در نمایه‌گر عملکرد پیدا کرد.

تأخیرهای ورودی هرگز نمی توانند صفر باشند، اما شما تا حدودی روی مدت زمان تأخیر ورودی کنترل دارید. نکته کلیدی این است که بفهمید آیا کاری روی رشته اصلی در حال اجرا است یا خیر که مانع از اجرای تماس های شما در اسرع وقت می شود.

تأخیر ورودی همانطور که در پانل عملکرد Chrome نشان داده شده است. شروع تعامل به طور قابل توجهی قبل از تماس مجدد رویداد به دلیل افزایش تاخیر ورودی به دلیل شلیک تایمر از یک اسکریپت شخص ثالث انجام می شود.
تأخیر ورودی ناشی از کار انجام شده توسط یک تایمر از یک اسکریپت شخص ثالث. قسمت سمت چپ سبیل در تعامل نشان داده شده در مسیر تعامل، تاخیر ورودی را به تصویر می کشد.

در شکل قبلی، یک کار از یک اسکریپت شخص ثالث در حال اجرا است که کاربر تلاش می کند با صفحه تعامل داشته باشد و بنابراین تاخیر ورودی را افزایش می دهد. تأخیر ورودی طولانی مدت تأخیر تعامل را تحت تأثیر قرار می دهد و بنابراین می تواند بر INP صفحه تأثیر بگذارد.

نحوه تشخیص مدت زمان پردازش طولانی

تماس‌های رویداد بلافاصله پس از تأخیر ورودی اجرا می‌شوند و زمان تکمیل آنها به عنوان مدت زمان پردازش شناخته می‌شود. اگر تماس‌های رویداد برای مدت طولانی اجرا شوند، مرورگر را از ارائه فریم بعدی به تأخیر می‌اندازند و می‌توانند به میزان قابل توجهی به تأخیر کل تعامل اضافه کنند. مدت زمان پردازش طولانی می تواند نتیجه محاسباتی گران قیمت جاوا اسکریپت شخص اول یا شخص ثالث باشد - و در برخی موارد، هر دو. در نمایه ساز عملکرد، این با بخش جامد تعامل در مسیر تعامل نشان داده می شود.

تصویری از وظایف بازگشت به تماس رویداد در پانل عملکرد Chrome. راهنمای ابزار شناور بر روی تعامل در جدول زمانی، مدت زمان پردازش طولانی را نشان می دهد.
همانطور که در نمایه‌ساز عملکرد در Chrome DevTools نشان داده شده است، رویداد در پاسخ به تعامل کلیک اجرا می‌شود. به مدت زمان پردازش بالا توجه کنید.

یافتن تماس های گران قیمت را می توان با مشاهده موارد زیر در ردیابی برای یک تعامل خاص انجام داد:

  1. تعیین کنید که آیا کار مرتبط با تماس های رویداد یک کار طولانی است یا خیر. برای اینکه کارهای طولانی را در تنظیمات آزمایشگاهی با اطمینان بیشتری نشان دهید، ممکن است لازم باشد که throttling CPU را در پانل عملکرد فعال کنید ، یا یک دستگاه Android سطح پایین به سطح متوسط ​​را متصل کنید و از اشکال زدایی از راه دور استفاده کنید.
  2. اگر وظیفه‌ای که تماس‌های رویداد را اجرا می‌کند، کار طولانی است، به دنبال ورودی‌های کنترل‌کننده رویداد - برای مثال، ورودی‌هایی با نام‌هایی مانند رویداد: کلیک کنید - در پشته تماس که دارای مثلث قرمز در گوشه سمت راست بالای ورودی هستند، بگردید.

می‌توانید یکی از استراتژی‌های زیر را برای کاهش مدت زمان پردازش یک تعامل امتحان کنید:

  1. تا حد امکان کمتر کار کنید. آیا هر اتفاقی که در یک رویداد گران قیمت رخ می دهد، کاملاً ضروری است؟ اگر نه، در صورت امکان آن کد را به طور کامل حذف کنید، یا اگر نمی توانید اجرای آن را به زمان دیگری موکول کنید. همچنین می توانید از ویژگی های چارچوب برای کمک استفاده کنید. برای مثال، ویژگی حافظه‌سازی React می‌تواند از کار رندر غیرضروری برای یک کامپوننت، زمانی که اجزای آن تغییر نکرده است، صرفنظر کند.
  2. کار غیر رندر در تماس برگشت رویداد را به زمان دیگری موکول کنید. کارهای طولانی را می توان با تسلیم شدن به موضوع اصلی شکست. هر زمان که به موضوع اصلی تسلیم شوید، اجرای وظیفه فعلی را پایان می دهید و باقی مانده کار را به یک کار جداگانه تقسیم می کنید. این به رندر فرصتی می‌دهد تا به‌روزرسانی‌های رابط کاربری را که قبلاً در بازگشت رویداد انجام شده بود، پردازش کند. اگر از React استفاده می کنید، ویژگی انتقال آن می تواند این کار را برای شما انجام دهد.

این استراتژی‌ها باید بتوانند به شما در بهینه‌سازی تماس‌های رویداد کمک کنند تا زمان کمتری برای اجرا صرف شود.

نحوه شناسایی تاخیرهای ارائه

تأخیرهای طولانی ورودی و مدت زمان پردازش تنها دلایل INP ضعیف نیستند. گاهی اوقات به‌روزرسانی‌های رندر که در پاسخ به حتی مقادیر کمی از کد برگشت رویداد رخ می‌دهند، ممکن است گران باشند. زمانی که مرورگر طول می‌کشد تا به‌روزرسانی‌های بصری را در رابط کاربری نمایش دهد تا نتیجه یک تعامل را منعکس کند، به عنوان تاخیر ارائه شناخته می‌شود.

رندر کردن کار همانطور که در پانل عملکرد Chrome DevTools تجسم شده است. کار رندر پس از بازگشت رویداد به منظور رنگ آمیزی فریم بعدی انجام می شود.
انجام وظایف همانطور که در نمایه‌ساز عملکرد Chrome نشان داده شده است. سبیل سمت راست طول تاخیرهای ارائه را به تصویر می کشد.

کار رندر اغلب شامل کارهایی مانند محاسبه مجدد سبک، چیدمان، رنگ و کامپوزیت است و با بلوک های بنفش و سبز در نمودار شعله پروفیل نشان داده می شود. کل تأخیر ارائه با سبیل سمت راست تعامل در مسیر تعامل نشان داده می شود.

از بین همه دلایل احتمالی تأخیر تعامل بالا، عیب‌یابی و رفع تأخیر ارائه می‌تواند سخت‌ترین باشد. کار رندر بیش از حد ممکن است به دلیل یکی از موارد زیر ایجاد شود:

  • اندازه های DOM بزرگ کار رندر مورد نیاز برای به روز رسانی ارائه صفحه اغلب همراه با اندازه DOM صفحه افزایش می یابد. برای اطلاعات بیشتر، بخوانید : اندازه‌های DOM بزرگ چگونه بر تعامل تأثیر می‌گذارند—و چه کاری می‌توانید در مورد آن انجام دهید .
  • جریان مجدد اجباری این زمانی اتفاق می‌افتد که تغییرات سبک را روی عناصر در جاوا اسکریپت اعمال می‌کنید و بلافاصله نتایج آن کار را جستجو می‌کنید. نتیجه این است که مرورگر باید قبل از انجام هر کار دیگری کار طرح بندی را انجام دهد تا مرورگر بتواند سبک های به روز شده را برگرداند. برای اطلاعات بیشتر و نکاتی در مورد اجتناب از جریان‌های مجدد اجباری، اجتناب از طرح‌بندی‌های بزرگ و پیچیده و کوبیدن طرح‌بندی را بخوانید.
  • کار بیش از حد یا غیر ضروری در requestAnimationFrame . فراخوانی requestAnimationFrame() در مرحله رندر حلقه رویداد اجرا می شود و باید قبل از ارائه فریم بعدی کامل شود. اگر از requestAnimationFrame() برای انجام کارهایی استفاده می کنید که شامل تغییراتی در رابط کاربری نمی شود، بدانید که ممکن است فریم بعدی را به تاخیر بیندازید.
  • ResizeObserver به تماس ها پاسخ می دهد. چنین تماس‌هایی قبل از رندر اجرا می‌شوند و ممکن است ارائه فریم بعدی را به تأخیر بیندازند اگر کار در آنها گران باشد. همانند تماس‌های رویداد، هر منطقی را که لازم نیست برای فریم بعدی به تعویق بیندازید.

اگر نتوانید یک تعامل آهسته را بازتولید کنید چه؟

اگر داده های میدانی شما نشان دهد که یک تعامل خاص کند است، اما نمی توانید به صورت دستی مشکل را در آزمایشگاه بازتولید کنید، چه؟ چند دلیل وجود دارد که چرا ممکن است چنین باشد.

به عنوان مثال، شرایط شما در هنگام آزمایش تعاملات به سخت افزار و اتصال شبکه شما بستگی دارد. ممکن است از یک دستگاه سریع در یک اتصال سریع استفاده کنید - اما این به این معنی نیست که کاربران شما این کار را می کنند. اگر این برای شما صدق می کند، می توانید یکی از سه مورد را امتحان کنید:

  1. اگر یک دستگاه Android فیزیکی دارید، از اشکال زدایی از راه دور برای باز کردن یک نمونه Chrome DevTools در دستگاه میزبان خود استفاده کنید و سعی کنید تعاملات کند را در آنجا بازتولید کنید. دستگاه های تلفن همراه اغلب به سرعت لپ تاپ ها یا دستگاه های رومیزی نیستند، بنابراین تعاملات آهسته ممکن است به راحتی در این دستگاه ها مشاهده شود.
  2. اگر دستگاه فیزیکی ندارید، ویژگی throttling CPU را در Chrome DevTools فعال کنید .

دلیل دیگر می تواند این باشد که شما منتظر هستید تا صفحه ای قبل از تعامل با آن بارگذاری شود، اما کاربران شما اینطور نیستند. اگر در یک شبکه سریع هستید، شرایط شبکه کندتر را با فعال کردن throttling شبکه شبیه‌سازی کنید، سپس به محض اینکه صفحه نقاشی کرد، با آن تعامل کنید. شما باید این کار را انجام دهید زیرا موضوع اصلی اغلب در هنگام راه اندازی شلوغ است و آزمایش در آن دوره زمانی ممکن است نشان دهد که کاربران شما چه چیزی را تجربه می کنند.

عیب یابی INP یک فرآیند تکراری است

یافتن علت تأخیر تعامل بالا که به INP ضعیف کمک می‌کند، کار زیادی می‌طلبد – اما اگر بتوانید دلایل را مشخص کنید، در نیمه راه هستید. با پیروی از یک رویکرد روشمند برای عیب یابی INP ضعیف، می توانید به طور قابل اعتماد آنچه را که باعث مشکل می شود مشخص کنید و سریعتر به راه حل مناسب برسید. به مرور:

آخرین مورد از اینها مهمترین است. مانند بسیاری از کارهای دیگری که برای بهبود عملکرد صفحه انجام می دهید، عیب یابی و بهبود INP یک فرآیند چرخه ای است. وقتی یک تعامل آهسته را برطرف کردید، به سراغ بعدی بروید و تا زمانی که شروع به دیدن نتایج کنید این کار را تکرار کنید.