1. 程式人生 > >js 返回上一頁並重新整理頁面

js 返回上一頁並重新整理頁面

正常情況下我們通過 history.back() 或者 history.go(-1) 返回上一級頁面的時候,是不會重新整理頁面的。這種不重新整理頁面包含兩種情況:

  1. 在 android 或者 pc 瀏覽器中看到的頁面有重新整理的效果,其實不是這樣的,這個時候的所有的資源都是從快取中載入來的。我們通過瀏覽器除錯工具可以看到 from disk cache 或者 from memory cache
  2. 在 ios 中甚至於返回到了上一頁後,連上一頁的指令碼檔案都沒有執行; (其實不是沒有執行,是執行了onpageshow)

上網搜尋 ios 返回上一頁並重新整理頁面的時候,會看到的解決方案有監聽 onpageshow

事件, 通過檢視文件可以知道 onpageshow 事件中,可以通過使用 PageTransitionEvent 物件的 persisted 屬性來判斷,頁面是直接從伺服器上載入還是從快取中讀取; 如果頁面從瀏覽器的快取中讀取該屬性返回 ture,否則返回 false

在 ios 中如果要實現,返回上一頁並重新整理頁面的話,可以在上一頁的指令碼檔案中加入如下程式碼:

window.addEventListener('pageshow', function(event) {
  if(event.persisted) { // ios 有效, android 和 pc 每次都是 false
sessionStorage.removeItem('refresh'); location.reload(); } });

但是這種方式在 android 和 pc 的瀏覽器中沒有效果,經過嘗試會發現 android 和 pc 的瀏覽器中每一次進入 pageshow事件後,event.persisted 永遠都是返回 false。
不管是在任何情況下,都會監聽到 pageshow事件。既然能進入這個函式,那就得想辦法在這個函式裡判斷是否需要重新整理頁面。可以通過快取的方式 localStoragesessionStoragecookie
要在頁面中判斷是否需要重新整理,那就得在從下一級返回過來的時候,往 cache

中存入需要重新整理。

sessionStorage.setItem('refresh', 'true');
history.go(-1);

然後在上一級也頁面獲取並判斷

if(sessionStorage.getItem('refresh') === 'true') {
  sessionStorage.removeItem('refresh');
  location.reload();
}

綜合相容所有裝置的返回上一頁並重新整理頁面的方式為:

window.addEventListener('pageshow', function(event) {
  if(event.persisted) { // ios 有效, android 和 pc 每次都是 false
    location.reload();
  } else { // ios 除外
    if(sessionStorage.getItem('refresh') === 'true') {
      location.reload();
    }
  }
  sessionStorage.removeItem('refresh');
});

注意:
1. 在下一級頁面返回的時候,要標記需要重新整理頁面(set)
2. 在判斷完成後,一定要刪除之前的儲存(remove)避免出現無限過載的情況