日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

JS如何实现返回上一页并刷新页面的方法

發布時間:2023/12/19 综合教程 24 生活家
生活随笔 收集整理的這篇文章主要介紹了 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)避免出現無限重載的情況

總結

以上是生活随笔為你收集整理的JS如何实现返回上一页并刷新页面的方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。