הפעלת bfcache עבור Cache-Control: no-store

אנחנו מבצעים שינוי ב-Chrome כדי לאפשר שימוש במטמון 'הקודם'/'הבא' (bfcache) בדפים שמשתמשים ב-Cache-Control: no-store כשהדבר בטוח. מה המשמעות של השינוי הזה למפתחים?

רקע

הגדרת Cache-Control: no-store ככותרת HTTP היא אות לכך שהדף לא צריך להישמר במטמון ה-HTTP. צריך להשתמש בהוראה הזו בדפים שמכילים מידע אישי רגיש – לדוגמה, בדפים שבהם משתמש מחובר לחשבון – אבל לעיתים קרובות משתמשים בהוראה no-store בדפים ללא מידע אישי רגיש.

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

אמנם אין דרישה כזו במפרט HTML, אבל בדרך כלל הדפדפנים מתייחסים ל-Cache-Control: no-store כאות להימנע משימוש במטמון לדף הקודם/הבא. זו הסיבה העיקרית לכך שלא נעשה שימוש ב-bfcache, ב-17% מהניווטים בהיסטוריה בנייד וב-7% מהניווטים בהיסטוריה במחשב. כלומר, הדפים האלה לא נהנים מהיתרונות של השחזור המהיר, וצריך לטעון מחדש את הדף במלואו, כולל כל הקריאות לרשת, ביצוע ה-JavaScript ועיבוד.

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

איך אנחנו משנים את ההתנהגות הזו ב-Chrome

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

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

מידע אישי רגיש

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

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

בנוסף, השימוש בממשקי ה-API הבאים בדפים שמשתמשים ב-Cache-Control: no-store ימשיך למנוע מהדפים האלה לעמוד בדרישות לשמירה במטמון לדף הקודם/הבא:

חשוב לזכור שזו לא רשימה מקיפה של ממשקי API שמונעים שימוש ב-bfcache, אלא ממשקי ה-API שחוסמים את bfcache בדפים מסוג Cache-Control: no-store גם אם לא נעשה בהם שימוש בזמן היציאה מהדף.

כדי לצמצם עוד יותר את הסיכון, גם זמן הקצאת הזמן הקצוב לתפוגה של bfcache לדפים עם Cache-Control: no-store צומצם ל-3 דקות (מ-10 דקות לדפים שלא משתמשים ב-Cache-Control: no-store).

ביטול הסכמה לארגונים

לרוב, בארגונים יש תוכנות ומכשירים משותפים שקשה לעדכן. אפשר להשבית את המדיניות AllowBackForwardCacheForCacheControlNoStorePageEnabled כדי להמשיך למנוע שימוש ב-bfcache בדפים מסוג Cache-Control: no-store.

בדיקת השינוי

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

--enable-features=CacheControlNoStoreEnterBackForwardCache:level/restore-unless-cookie-change

אם אחד מהחריגים הקודמים רלוונטי – למשל, שינוי של קובצי cookie – הדף לא יוכל להשתמש ב-bfcache, והסיבה לכך תופיע בבודק ה-bfcache של Chrome DevTools: "דפים שהמשאב הראשי שלהם מכיל את Cache-Control: no-store לא יכולים להיכנס למטמון לדף הקודם/הבא".

אפשר להשתמש בדף הבדיקה של bfcache כדי לבדוק עם הדגל הזה וגם בלי הדגל הזה.

מידע למפתחים

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

ההשפעה על הביצועים

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

בעלי אתרים עשויים לראות שיפור במדדי הליבה לבדיקת חוויית המשתמש באתר במהלך ההשקה, ויכולים למדוד את השימוש ב-bfcache ב-CrUX, כולל בלוח הבקרה של CrUX.

ניתוח השפעות

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

לכן, יכול להיות שבאתרים שיתחילו להשתמש ב-bfcache בפעם הראשונה תהיה ירידה בטעינות הדפים בניתוח הנתונים. מומלץ להתייחס לאירועים האלה כצפיות בדפים, על ידי הגדרת מאזינים לאירוע pageshow ובדיקת המאפיין persisted:

// Send a pageview when the page is first loaded.
gtag('event', 'page_view');

// Send another pageview if the page is restored from bfcache.
window.addEventListener('pageshow', (event) => {
  if (event.persisted) {
    // Page was restored from bfcache, sent another page view.
    gtag('event', 'page_view');
  }
});

טיפול בעדכונים בשחזור דפים

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

אפשר להפעיל עדכונים באופן דומה לרישום אירועי צפייה בדפים נוספים לצורכי ניתוח באמצעות האירוע pageshow ובדיקת המאפיין persisted.

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

ההשפעה על המודעות

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

מידע נוסף על bfcache

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

משוב

נשמח לקבל מכם משוב על השינוי הזה. תוכלו לשלוח אותו בכלי למעקב אחר בעיות ב-Chrome באמצעות הרכיב bfcache.

סיכום

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