bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

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如何實現返回上一頁并刷新頁面的方法”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

分享名稱:JS如何實現返回上一頁并刷新頁面的方法
分享鏈接:http://vcdvsql.cn/article16/pccegg.html

成都網站建設公司_創新互聯,為您提供網站內鏈、小程序開發、網站設計App開發、品牌網站設計企業建站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

網站建設網站維護公司