מה חדש ב-Lighthouse 10

Lighthouse הוא כלי לבדיקת אתרים שעוזר למפתחים לזהות הזדמנויות ואבחונים לשיפור חוויית המשתמש באתרים שלהם.

Lighthouse 10 זמין באופן מיידי בשורת הפקודה דרך npm וב-Chrome Canary. התכונה תגיע לגרסה היציבה של Chrome בגרסה 112 וב-PageSpeed Insights בשבועות הקרובים.

שינויים בסכימה למתן ציונים

המדד הוותיק זמן לאפשרות אינטראקציה (TTI) יוסר ב-Lighthouse 10, כחלק מתהליך ההוצאה משימוש שהחל ב-Lighthouse 8. משקל הציון של TTI (10%) מועבר ל-Cumulative Layout Shift‏ (CLS), שייחשב מעכשיו ל-25% מתוך ציון הביצועים הכולל.

המדד TTI מציין נקודה בזמן, אבל האופן שבו הוא מוגדר הופך אותו לרגיש מדי לבקשות חריגות מהרשת ולמשימות ארוכות. בדרך כלל, Largest Contentful Paint ‏ (LCP) ו-Speed Index הם שיטות ניתוח חזותיות טובות יותר לתחושה שהתוכן של הדף נטען, מאשר ספירת הבקשות הפעילות לרשת. לעומת זאת, זמן החסימה הכולל (TBT) מטפל במשימות ארוכות ובזמינות של ה-thread הראשי בצורה חזקה יותר, והוא אמנם לא מדד עקיף, אבל יש לו קורלציה טובה יותר עם הנתונים הבסיסיים על חוויית המשתמש (Core Web Vitals) כפי שנמדדים בשטח.

המשקל המוגבר של CLS הוא תופעה נלווית להסרת TTI, אבל הוא משקף טוב יותר את החשיבות שלו כמדד Core Web Vitals, ובאופן אידיאלי יגדיל את המיקוד באתרים שעדיין מבצעים שינויי פריסה מיותרים.

אנחנו צופים שהשינוי הזה ישפר את ציוני הביצועים של רוב הדפים, כי רוב הדפים נוטים לקבל ציון גבוה יותר במדד CLS מאשר במדד TTI. בניתוח של 13 מיליון טעינות דפים במהלך ההרצה האחרונה של HTTP Archive, 90% מהדפים האלה יהיו עם שיפור בציון הביצועים של Lighthouse, ו-50% מהם יהיו עם שיפור בביצועים של יותר מ-5 נקודות.

מדד של ציון Lighthouse, עם פירוט של המדדים (FCP,‏ SI,‏ LCP,‏ TBT ו-CLS) שמרכיבים את הציון הכולל

אם מסיבה כלשהי אתם עדיין צריכים את הערך של TTI ב-Lighthouse (לדוגמה, בטענת נכוֹנוּת (assertion) של CI), הוא עדיין זמין ללא שינוי בפלט ה-JSON של Lighthouse, רק עם משקל ניקוד 0 והוא מוסתר בדוח ה-HTML. כל גישה לפי סקריפט של ערך ה-JSON אמורה להמשיך לפעול ללא שינויים.

ביקורות חדשות

ב-Lighthouse 10 יש ביקורת ביצועים חדשה לגמרי ושינוי משמעותי בביקורת אחרת.

מטמון לדף הקודם/הבא

המטמון לדף הקודם/הבא (bfcache) הוא אחד הכלים היעילים ביותר שזמינים לשיפור הביצועים של דף למשתמשים אמיתיים. מעבר למטמון הרגיל של הדפדפן, דף שנטען מ-bfcache ישחזר את פריסת הדף ואת מצב הביצוע שלו כמעט באופן מיידי, וידלג על רוב הפעילות של טעינת הדף, כך שהדף יוצג למשתמשים באופן מיידי כשהם מנווטים אחורה וקדימה בהיסטוריה שלהם.

עם זאת, יש כמה דרכים שבהן דף יכול למנוע מהדפדפן לשחזר דף מהמטמון לדף הקודם/הבא. בבדיקה החדשה של Lighthouse, הדף נטען מחוץ לדף הבדיקה ואז חוזר אליו כדי לבדוק אם אפשר לשמור אותו במטמון bfcache, ומפורטים בו הסיבות לכך אם הוא לא עומד בדרישות.

דוגמה לתוצאה מביקורת bfcache, שמציגה כשלים שנובעים מחיבור פתוח של IndexDB וממטפלים בפריקה בדף

מידע נוסף זמין במסמכי התיעוד של ביקורת bfcache.

נתוני קלט שחוסמים הדבקה

הביקורת הקודמת של השיטות המומלצות 'משתמשים יכולים להדביק תוכן מועתק לתוך שדות של סיסמאות' הורחבה, וכעת היא כוללת בדיקה של היכולת להדביק בכל שדה קלט (שאינו לקריאה בלבד). ברוב האתרים, מניעת הדבקה גורמת לחוויית משתמש שלילית בסך הכול, ומונעת תהליכי עבודה לגיטימיים של בטיחות ונגישות.

הביקורת החדשה היא 'משתמשים יכולים להדביק בשדות להזנת קלט' (paste-preventing-inputs).

משתמשי צומת

אם אתם משתמשים ב-Lighthouse כספריית Node, יש כמה שינויים תוכנות משמעותיים במהדורה הזו שצריך לקחת בחשבון. פרטים מלאים זמינים ביומן השינויים של גרסה 10.0.

ב-Lighthouse 10 יש גם הצהרות מלאות על סוגי TypeScript! עכשיו צריך להקליד כל דבר שייבא מ-lighthouse. האפשרות הזו שימושית במיוחד אם אתם כותבים סקריפטים לתהליכי משתמש ב-Lighthouse.

סקריפט Node שמייבא את Lighthouse כפונקציה, ומראה שאובייקט האפשרויות שמוענק לפונקציה עובר עכשיו בדיקת סוג על ידי TypeScript

נסו את הסוגים השונים ותודיעו לנו אם נתקלתם בבעיות בשימוש בהם.

הפעלת Lighthouse

Lighthouse זמין ב-Chrome DevTools, ב-npm (כמודול Node וככלי CLI) וכתוסף לדפדפן (ב-Chrome וב-Firefox). הוא גם מניע כמה שירותי Google, כולל PageSpeed Insights.

כדי לנסות את ה-CLI של Lighthouse Node, משתמשים בפקודות הבאות:

npm install -g lighthouse
lighthouse https://www.example.com --view

יצירת קשר עם צוות Lighthouse

כדי לדון בתכונות החדשות, בשינויים בגרסה 10 של Lighthouse או בכל דבר אחר שקשור ל-Lighthouse: