פונקציות ה-event listener הקשורות למגע ולגלגלת הן שימושיות לצורך מעקב אחרי אינטראקציות של משתמשים ויצירת חוויות גלילה בהתאמה אישית, אבל הן גם יכולות לעכב את הגלילה בדף. בשלב זה, דפדפנים לא יכולים לדעת אם event listener ימנע גלילה, לכן הם תמיד ממתינים עד שה-listener יסיים את הביצוע לפני הגלילה של הדף. פונקציות event listener פסיביות פותרים את הבעיה הזו בכך שהם מאפשרים לכם לציין ש-event listener אף פעם לא ימנע גלילה.
תאימות דפדפן
רוב הדפדפנים תומכים בפונקציות event listener פסיביות. למידע נוסף, ראו תאימות דפדפן
איך נכשלת הבדיקה של פונקציות event listener פסיביות של Lighthouse
התכונה Lighthouse מסמנת פונקציות event listener שעלולות לעכב את גלילת הדף:
ב-Lighthouse נעשה שימוש בתהליך הבא כדי לזהות פונקציות event listener שיכולות להשפיע על ביצועי הגלילה:
- אספו את כל פונקציות ה-event listener שבדף.
- סינון מאזינים ללא מגע וללא גלגלים.
- סינון מאזינים שמתקשרים אל
preventDefault()
. - אפשר לסנן מאזינים שהם לא ממארח של הדף.
מערכת Lighthouse מסננת מאזינים ממארחים שונים כי סביר להניח שאין לכם שליטה על הסקריפטים האלה. יכול להיות שיש סקריפטים של צד שלישי שפוגעים בביצועי הגלילה של הדף, אבל הם לא רשומים בדוח Lighthouse.
איך להפוך פונקציות event listener פסיביות כדי לשפר את ביצועי הגלילה
יש להוסיף סימון passive
לכל event listener ש-Lighthouse זיהה.
אם אתם תומכים רק בדפדפנים עם תמיכה פסיבית ב-event listener, פשוט הוסיפו את הדגל. לדוגמה:
document.addEventListener('touchstart', onTouchStart, {passive: true});
אם אתם תומכים בדפדפנים ישנים יותר שלא תומכים ב-event listener פסיבי, תצטרכו להשתמש בזיהוי תכונות או ב-polyfill. למידע נוסף, עיינו בקטע זיהוי תכונות במסמך ההסבר WICG Passive event listeners.