永久儲存空間

永久性儲存空間可保護重要資料,避免遭到淘汰,並降低資料遺失的機率。

當瀏覽器面臨儲存空間壓力 (例如磁碟空間不足) 時,通常會從最近最少使用的來源淘汰資料,包括 Cache API 和 IndexedDB。如果應用程式未與伺服器同步處理資料,這可能會導致資料遺失,並移除應用程式運作所需的資源,進而降低應用程式的可靠性,兩者都會導致使用者體驗不佳。

幸好,Chrome 團隊的研究顯示,Chrome 很少自動清除資料。使用者通常會手動清除儲存空間。因此,如果使用者定期造訪您的網站,資料就不會遭到淘汰。如要避免瀏覽器刪除您的資料,您可以要求將整個網站的儲存空間標示為永久性。

許多新式瀏覽器都支援永久儲存空間。

瀏覽器支援

  • Chrome:55。
  • Edge:79。
  • Firefox:57。
  • Safari:15.2。

資料來源

如要進一步瞭解淘汰機制、可儲存的資料量,以及如何處理配額限制,請參閱「Web Storage」。

檢查網站儲存空間是否已標示為永久

您可以利用 JavaScript 判斷網站儲存空間是否已標示為永久儲存空間。呼叫 navigator.storage.persisted() 會傳回 Promise,該 Promise 是以布林值解析,指出儲存空間是否已標示為永久性。

// Check if site's storage has been marked as persistent
if (navigator.storage && navigator.storage.persist) {
  const isPersisted = await navigator.storage.persisted();
  console.log(`Persisted storage granted: ${isPersisted}`);
}

何時該要求永久儲存空間?

要求儲存空間標示為持久性儲存空間的最佳時機,是在您儲存重要使用者資料時,且要求應以使用者手勢包裝為佳。請勿在載入網頁時要求永久儲存空間;在其他 Bootstrap 程式碼中,瀏覽器可能會提示使用者授予權限。如果使用者未執行任何認為需要儲存的行為,提示可能會令人困惑,甚至拒絕要求。此外,請勿過度頻繁顯示提示。如果使用者決定不授予權限,下次儲存時,不要立即顯示提示。

要求永久儲存空間

如要為網站資料要求持久性儲存空間,請呼叫 navigator.storage.persist()。這個方法會傳回 Promise,並以布林值解析,指出是否已授予永久性儲存空間權限。

// Request persistent storage for site
if (navigator.storage && navigator.storage.persist) {
  const isPersisted = await navigator.storage.persist();
  console.log(`Persisted storage granted: ${isPersisted}`);
}

如何授予權限?

永久儲存空間會視為權限。瀏覽器會根據不同因素決定是否授予永久性儲存空間權限。

Chrome 和其他以 Chromium 為基礎的瀏覽器

Chrome 和大多數以 Chromium 為基礎的瀏覽器會自動處理權限要求,不會向使用者顯示任何提示。相反地,如果網站很重要,系統會自動授予永久儲存空間權限,否則會在不發出通知的情況下拒絕權限。

判斷網站是否重要時,系統會使用下列經驗法則:

  • 網站參與度有多高?
  • 網站是否已安裝或加入書籤?
  • 網站是否已獲得顯示通知的權限?

如果要求遭到拒絕,您可以稍後再次提出要求,系統會使用相同的推論法進行評估。

Firefox

Firefox 會將權限要求委派給使用者。要求永久性儲存空間時,系統會透過 UI 彈出式視窗提示使用者,詢問他們是否允許網站在永久性儲存空間中儲存資料。

網站要求持續性儲存空間時,Firefox 會顯示的彈出式視窗。
網站要求永久儲存空間時,Firefox 顯示的彈出式視窗。

永久儲存空間可保護哪些儲存空間?

如果授予永久性儲存空間權限,瀏覽器就不會移除儲存在以下位置的資料:

  • Cache API
  • Cookie
  • DOM 儲存空間 (本機儲存空間)
  • File System API (瀏覽器提供的沙箱檔案系統)
  • IndexedDB
  • Service Worker
  • 應用程式快取 (已淘汰,不應使用)
  • WebSQL (已淘汰,不應使用)

如何關閉永久儲存空間

目前,您無法透過程式輔助方式告訴瀏覽器不需要永久儲存空間。

結論

Chrome 團隊的研究顯示,雖然情況允許,Chrome 鮮少自動清除儲存的資料。如要保護可能無法儲存在雲端的重要資料,或可能導致大量資料遺失,永久儲存空間是一項實用的工具,確保本機裝置面臨儲存空間壓力時,不會移除瀏覽器中的資料。請記住,請務必在使用者最有可能需要時,才要求持久性儲存空間。

謝謝

特別感謝 Victor Costan 和 Joe Medley 審查本文。感謝 Chris Wilson,撰寫本文的原版文章,首次出現在 WebFundamentals。

主頁橫幅圖片由 Umberto 提供,取自 Unsplash