欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實現(xiàn)返回上一頁并刷新頁面的方法分析

 更新時間:2019年07月16日 11:48:27   作者:愛在彩虹  
這篇文章主要介紹了JS實現(xiàn)返回上一頁并刷新頁面的方法,結(jié)合實例形式分析了javascript針對移動端、PC端瀏覽器的頁面緩存刷新相關(guān)操作技巧,需要的朋友可以參考下

本文實例講述了JS實現(xiàn)返回上一頁并刷新頁面的方法。分享給大家供大家參考,具體如下:

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

  1. 在 android 或者 pc 瀏覽器中看到的頁面有刷新的效果,其實不是這樣的,這個時候的所有的資源都是從緩存中加載來的。我們通過瀏覽器調(diào)試工具可以看到 from disk cache 或者 from memory cache。
  2. 在 ios 中甚至于返回到了上一頁后,連上一頁的腳本文件都沒有執(zhí)行; (其實不是沒有執(zhí)行,是執(zhí)行了onpageshow)

上網(wǎng)搜索 ios 返回上一頁并刷新頁面的時候,會看到的解決方案有監(jiān)聽 onpageshow 事件, 通過查看文檔可以知道 onpageshow 事件中,可以通過使用 PageTransitionEvent 對象的 persisted 屬性來判斷,頁面是直接從服務(wù)器上載入還是從緩存中讀?。?如果頁面從瀏覽器的緩存中讀取該屬性返回 ture,否則返回 false

在 ios 中如果要實現(xiàn),返回上一頁并刷新頁面的話,可以在上一頁的腳本文件中加入如下代碼:

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

但是這種方式在 android 和 pc 的瀏覽器中沒有效果,經(jīng)過嘗試會發(fā)現(xiàn) android 和 pc 的瀏覽器中每一次進入 pageshow事件后,event.persisted 永遠(yuǎn)都是返回 false。

不管是在任何情況下,都會監(jiān)聽到 pageshow事件。既然能進入這個函數(shù),那就得想辦法在這個函數(shù)里判斷是否需要刷新頁面。可以通過緩存的方式 localStoragesessionStoragecookie。

要在頁面中判斷是否需要刷新,那就得在從下一級返回過來的時候,往 cache中存入需要刷新。

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

然后在上一級也頁面獲取并判斷

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

綜合兼容所有設(shè)備的返回上一頁并刷新頁面的方式為:

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. 在下一級頁面返回的時候,要標(biāo)記需要刷新頁面(set)

2. 在判斷完成后,一定要刪除之前的存儲(remove)避免出現(xiàn)無限重載的情況

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript頁面元素操作技巧總結(jié)》、《JavaScript操作DOM技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

最新評論