כללי ספקולציות לניפוי באגים באמצעות כלי הפיתוח ל-Chrome

אפשר להשתמש בכללי השערות כדי לבצע טעינה מראש של ניווט לדפים הבאים ולבצע עיבוד מראש שלהם, כפי שמתואר בפוסט הקודם. כך אפשר לטעון דפים מהר יותר – או אפילו באופן מיידי – ולשפר באופן משמעותי את מדדי Core Web Vitals במעברים הנוספים לדפים.

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

צוות Chrome עבד קשה כדי לשפר את התמיכה של DevTools בניפוי באגים של כללי השערות. בפוסט הזה נסביר על כל הדרכים השונות שבהן אפשר להשתמש בכלים האלה כדי להבין את כללי ההשערות של דף, למה יכול להיות שהם לא פועלים ומתי מפתחים יכולים להשתמש באפשרויות המוכרות יותר של DevTools – ומתי לא.

הסבר על המונחים 'pre-'

יש הרבה מונחים עם 'טרום' שמבלבלים, לכן נתחיל בהסבר על המונחים הבאים:

  • אחזור מראש: אחזור מראש של משאב או מסמך כדי לשפר את הביצועים בעתיד. הפוסט הזה עוסק בהטמעת prefetching של מסמכים באמצעות Speculation Rules API, ולא באפשרות <link rel="prefetch"> הדומה אך הישנה יותר, שמשמשת לעתים קרובות להטמעת prefetching של משאבי משנה.
  • עיבוד מראש: התהליך הזה הולך צעד אחד קדימה מעבר לטעינה מראש, ומעבד בפועל את הדף כולו כאילו המשתמש מנווט אליו, אבל שומר אותו בתהליך עיבוד מוסתר ברקע, מוכן לשימוש אם המשתמש מנווט אליו בפועל. שוב, המסמך הזה מתייחס לגרסה החדשה יותר של Speculation Rules API, ולא לאפשרות הישנה יותר <link rel="prerender"> (שכבר לא מבצעת עיבוד מראש מלא).
  • ניווטים ספקולטיביים: המונח הכולל לאפשרויות החדשות של טעינה מראש ועיבוד מראש שמופעל על ידי כללי ספקולציה.
  • טעינה מראש: מונח בעל עומס יתר שיכול להתייחס למספר טכנולוגיות ותהליכים, כולל <link rel="preload">, סורק הטעינה מראש וטעינות מראש של ניווט של שירותי עבודה. הפריטים האלה לא ייכללו כאן, אבל המונח נכלל כדי להבדיל בבירור בין הפריטים האלה לבין המונח 'ניווטים ספקולטיביים'.

כללי ספקולציות בחשבון prefetch

אפשר להשתמש בכללי ספקולציות כדי לבצע אחסון מראש של המסמך הבא בניווט. לדוגמה, כשמוסיפים את ה-JSON הבא לדף, next.html ו-next2.html יאוחסנו מראש:

<script type="speculationrules">
  {
    "prefetch": [
      {
        "source": "list",
        "urls": ["next.html", "next2.html"]
      }
    ]
  }
</script>

לשימוש בכללי השערות להטמעה מראש של נתוני ניווט יש כמה יתרונות על פני התחביר הישן של <link rel="prefetch">, כמו API חזותי יותר והעובדה שהתוצאות מאוחסנות במטמון בזיכרון ולא במטמון הדיסק של HTTP.

ניפוי באגים של כללי ספקולציות prefetch

אחזור מראש שמופעל על ידי כללי ספקולציה מופיע בחלונית רשת באותו אופן שבו מופיע אחזור אחר:

חלונית הרשת ב-Chrome DevTools שמוצגים בה מסמכים שנשמרו מראש
חלונית הרשת בכלי הפיתוח ל-Chrome שמוצגים בה מסמכים שנשמרו מראש

שתי הבקשות שמודגשות באדום הן המשאבים שאוחסנו מראש, כפי שאפשר לראות בעמודה Type. הם מאוחזרים בעדיפות Lowest כי הם מיועדים לניווטים עתידיים, ו-Chrome נותן עדיפות למשאבים של הדף הנוכחי.

לחיצה על אחת מהשורות תציג גם את כותרת ה-HTTP‏ Sec-Purpose: prefetch, שבאמצעותה אפשר לזהות את הבקשות האלה בצד השרת:

כותרות של טעינה מראש ב-Chrome DevTools עם Sec-Purpose שמוגדר לטעינה מראש
כותרות של אחסון מקדים ב-Chrome DevTools עם Sec-Purpose מוגדר לאחסון מקדים

ניפוי באגים ב-prefetch באמצעות הכרטיסיות 'טעינה ספקולטיבית'

הוספנו קטע חדש בשם Speculative loads (עומסים ספקולטיביים) בחלונית Application (אפליקציה) של כלי הפיתוח של Chrome, בקטע Background services (שירותי רקע), כדי לעזור בניפוי באגים של כללי השערות:

כרטיסיות של טעינה משוערת בכלי הפיתוח ל-Chrome שמוצג בהן כלל של טעינה מראש
כרטיסיות של טעינה ספקולטיבית בכלי הפיתוח ל-Chrome שמוצגת בהן כלל של טעינה מראש

יש שלוש כרטיסיות בקטע הזה:

  • טעינות ספקולטיביות, שבהן מוצג הסטטוס של הדף הנוכחי שעבר עיבוד מראש.
  • כללים, שמציג את כל קבוצות הכללים שנמצאות בדף הנוכחי.
  • ספקולציות, שבהן מפורטות כל כתובות ה-URL שנשמרו מראש ועוברו עיבוד מראש מקבוצות הכללים.

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

בכרטיסייה Speculations מפורטות כל כתובות ה-URL של היעד, יחד עם הפעולה (אחסון מקדים או עיבוד מראש), קבוצת הכללים שממנה הן הגיעו (יכולות להיות כמה קבוצות כללים בדף) והסטטוס של כל השערות:

הכרטיסייה &#39;השערות&#39; בכלי הפיתוח ל-Chrome, שבה מוצגות כתובות URL שאוחזרו מראש לצד הסטטוס שלהן
הכרטיסייה 'השערות' בכלי הפיתוח ל-Chrome, שבה מוצגות כתובות URL שאוחסנו מראש עם הסטטוס שלהן

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

בצילום המסך הזה אפשר לראות את הסיבה לכישלון בדף next3.html (הדף לא קיים ולכן מוחזר קוד סטטוס 404, שהוא לא קוד סטטוס HTTP מסוג 2xx).

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

בדף שעבר אחסון מראש, אמורה להופיע הודעה על הצלחה כשעוברים אליו:

בכרטיסייה &#39;טעינות ספקולטיביות&#39; בכלי הפיתוח ל-Chrome מוצגת טעינה מראש מוצלחת
כרטיסיית Speculative loads (עומסים ספקולטיביים) בכלי הפיתוח ל-Chrome, שבה מוצגת טעינה מראש מוצלחת

ספקולציות שלא תאמו

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

הכרטיסייה &#39;טעינות ספקולטיביות&#39; בכלי הפיתוח ל-Chrome, שבה מוצג שהכתובת הנוכחית לא תאמה לאף אחת מכתובות ה-URL בכללי הספקולציה של הדף הקודם
כתובות URL שלא נמצאו להן התאמות מודגשות בכלי הפיתוח

לדוגמה, כאן פנינו אל next4.html, אבל רק next.html,‏ next2.html או next3.html הם טעינות מראש, כך שאפשר לראות שהדף הזה לא תואם לאף אחד משלושת הכללים האלה.

הכרטיסיות Speculative loads (עומסים ספקולטיביים) שימושיות מאוד לניפוי באגים בכללי הספיקולציה עצמם, ולזיהוי שגיאות תחביר ב-JSON.

לגבי הטעינות מראש עצמן, סביר להניח שהחלונית רשת מוכרת יותר. בדוגמה של כשל של טעינה מראש, אפשר לראות את השגיאה 404 של הטעינה מראש כאן:

חלונית הרשת של כלי הפיתוח ל-Chrome שבה מוצגת טעינה מראש שנכשלה
חלונית הרשת של כלי הפיתוח ל-Chrome שמוצגת בה טעינה מראש שנכשלה

עם זאת, הכרטיסיות טעינות ספקולטיביות הופכות לשימושיות הרבה יותר כשמדובר בכללי ספקולציות לעיבוד מראש. הנושא הזה ייבדק בהמשך.

כללי ספקולציות בחשבון prerender

כללי הספקולציות של עיבוד מראש פועלים לפי אותו תחביר של כללי הספקולציות של טעינה מראש. לדוגמה:

<script type="speculationrules">
  {
    "prerender": [
      {
        "source": "list",
        "urls": ["next.html", "next2.html"]
      }
    ]
  }
</script>

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

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

ניפוי באגים ב-prerender באמצעות הכרטיסיות 'טעינות ספקולטיביות'

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

כלי הפיתוח ל-Chrome מבצע טעינה ספקולטיבית של כרטיסיות לדף עם כללי ספקולציה לעיבוד מראש
כלי הפיתוח ל-Chrome מעמיסים כרטיסיות באופן משוער לדף עם כללי השערה מראש לעיבוד (prerender)

כאן שוב רואים שאחת משלוש כתובות ה-URL נכשלה ברינדור מראש, ומפתחים יכולים לקבל את הפרטים לכל כתובת URL בכרטיסייה Speculations (ספקולציות) בלחיצה על הקישור 2 Ready, 1 Failure (2 מוכנות, 1 כשל).

ב-גרסה 121 של Chrome השקנו תמיכה בכללי מסמכים. כך הדפדפן יכול לזהות אותם מקישורים מאותו מקור בדף, במקום לרשום קבוצה ספציפית של כתובות URL:

<script type="speculationrules">
{
  "prerender": [
    {
      "source": "document",
      "where": {
        "and": [
          {"href_matches": "/*"},
          {"not": { "href_matches": "/not-safe-to-prerender/*"}}
        ]
      },
      "eagerness": "moderate"
    }
  ]
}
</script>

בדוגמה הזו, כל הקישורים מאותו מקור נבחרים כמועמדים לעיבוד מראש, מלבד אלה שמתחילים ב-/not-safe-to-prerender.

הוא גם מגדיר את ה-prerender eagerness לערך moderate, כלומר הניווטים עוברים עיבוד מראש כשעובר מעל הקישור או לוחצים עליו.

יש כללים דומים לזה באתר הדגמה של הכללים השערוריתיים, והשימוש בקטע החדש Speculative loads (עומסים ספקולטיביים) באתר הזה מראה את התועלת של הכרטיסייה החדשה הזו, כי כל כתובות ה-URL שעומדות בדרישות והדפדפן מצא בדף מפורטות שם:

הכרטיסייה &#39;השערות&#39; בכלי הפיתוח ל-Chrome עם מספר כתובות URL שלא הופעלו
הכרטיסייה 'השערות' בכלי הפיתוח ל-Chrome עם מספר כתובות URL שלא הופעלו

הסטטוס הוא לא הופעל כי תהליך העיבוד מראש שלהם לא התחיל. עם זאת, כשאנחנו מחזיקים את הסמן מעל הקישורים, אנחנו רואים את הסטטוס משתנה ככל שכל כתובת URL עוברת עיבוד מראש:

כרטיסיית השערות בכלי הפיתוח ל-Chrome עם דפים שעברו עיבוד מראש שהופעלו
הכרטיסייה 'השערות' בכלי הפיתוח ל-Chrome עם דפים שעברו עיבוד מראש שהופעלו

ב-Chrome מוגדרות מגבלות על עיבוד מראש, כולל 2 עיבודים מראש לכל היותר לצורך moderate, כך שלאחר העברת העכבר מעל הקישור השלישי, מוצגת הסיבה לכישלון של כתובת ה-URL הזו:

כרטיסיית השערות בכלי הפיתוח ל-Chrome עם הצגה של טעימות שנכשלו לטעינת נתונים מראש
הכרטיסייה 'השערות' בכלי הפיתוח ל-Chrome, עם הצגה של טעימות שנכשלו

ניפוי באגים ב-prerender באמצעות שאר החלוניות של כלי הפיתוח

בניגוד לטעינה מראש, דפים שעברו עיבוד מראש לא יופיעו בתהליכי העיבוד הנוכחיים בחלוניות של DevTools, כמו החלונית רשת, כי הם עוברים עיבוד במעבד משלהם שמופעל מאחורי הקלעים.

עם זאת, עכשיו אפשר להחליף את המנגנון להצגת גרפיקה שמשמש את חלוניות כלי הפיתוח באמצעות התפריט הנפתח בפינה השמאלית העליונה, או על ידי בחירה בכתובת URL בחלק העליון של החלונית ובחירה באפשרות בדיקה:

עכשיו אפשר להחליף את המכשירים שבהם מוצג המידע בכלי הפיתוח של Chrome
כלי הפיתוח ל-Chrome מאפשרים עכשיו להחליף את המכשירים שבהם המידע מוצג

התפריט הנפתח הזה (והערך שנבחר) משותפים גם בכל שאר החלוניות, כמו החלונית רשת, שבה אפשר לראות שהדף המבוקש הוא הדף שעבר עיבוד מראש:

חלונית הרשת בכלי הפיתוח של Chrome, שבה מוצגות בקשות הרשת לדף שעבר עיבוד מראש
החלונית 'רשת' בכלי הפיתוח ל-Chrome, שבה מוצגות בקשות הרשת לדף שעבר עיבוד מראש

כשבודקים את כותרות ה-HTTP של המשאבים האלה, רואים שכולן יוגדרו עם הכותרת Sec-Purpose: prefetch;prerender:

חלונית הרשת של כלי הפיתוח ל-Chrome שבה מוצג הכותרת Sec-Purpose לדף שעבר עיבוד מראש
החלונית 'רשת' בכלי הפיתוח ל-Chrome, שבה מוצג הכותרת Sec-Purpose לדף שעבר עיבוד מראש

לחלופין, אפשר להשתמש בחלונית Elements (רכיבים), שבה מוצגים תוכן הדף. לדוגמה, בצילום המסך הבא רואים שהרכיב <h1> מייצג את הדף שעבר עיבוד מראש:

חלונית הרכיבים של כלי הפיתוח ל-Chrome לדף שעבר עיבוד מראש
החלונית Elements (רכיבים) בכלי הפיתוח ל-Chrome לדף שעבר עיבוד מראש

אפשר גם להשתמש בחלונית מסוף, שבה מוצגים יומני מסוף שנוצרו על ידי הדף שעבר עיבוד מראש:

חלונית המסוף של Chrome DevTools שבה מוצג הפלט של המסוף מדף שעבר רינדור מראש
חלונית מסוף כלי הפיתוח ל-Chrome שמוצגת בה הפלט של המסוף מדף שעבר עיבוד מראש

ניפוי באגים של כללי ספקולציות בדף שעבר עיבוד מראש

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

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

הכרטיסייה &#39;טעינות ספקולטיביות&#39; בכלי הפיתוח ל-Chrome, שבה מוצגים דף שעבר עיבוד מראש בהצלחה ודף שעבר עיבוד מראש אבל נכשל
הכרטיסייה 'טעינות ספקולטיביות' בכלי הפיתוח ל-Chrome, שבה מוצגים דף שעבר עיבוד מראש בהצלחה ודף שעבר עיבוד מראש אבל נכשל

בנוסף, כמו במקרה של שליפה מראש (prefetch), ניווט מדף עם כללי ספקולציה שלא התאימו לדף הנוכחי ינסה להראות לכם בכרטיסייה טעינות ספקולטיביות למה כתובות ה-URL לא התאימו לכתובות הכלולות בכללי הספקולציה של הדף הקודם:

הכרטיסייה &#39;טעינות ספקולטיביות&#39; בכלי הפיתוח ל-Chrome, שבה מוצגת אי ההתאמה בין כתובת ה-URL הנוכחית לכתובות ה-URL שכלולות בדף הקודם
כלי הפיתוח ל-Chrome שמוצגות בו חוסר ההתאמות בכתובות ה-URL

סיכום

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

תודות

תמונה ממוזערת של Nubelson Fernandes ב-Unsplash.