国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JS實現返回上一頁并刷新頁面的方法分析

2024-05-06 16:53:22
字體:
來源:轉載
供稿:網友

本文實例講述了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事件。既然能進入這個函數,那就得想辦法在這個函數里判斷是否需要刷新頁面??梢酝ㄟ^緩存的方式 localStorage 或 sessionStorage 或 cookie。

要在頁面中判斷是否需要刷新,那就得在從下一級返回過來的時候,往 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)避免出現無限重載的情況

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


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 勃利县| 沙雅县| 张家口市| 敦煌市| 察隅县| 宜兰县| 安塞县| 台州市| 陈巴尔虎旗| 松溪县| 邛崃市| 黑山县| 乡宁县| 沛县| 都昌县| 拉萨市| 岳普湖县| 江华| 望谟县| 金塔县| 双辽市| 澄江县| 海林市| 布拖县| 枣强县| 定远县| 青川县| 化州市| 永胜县| 兰州市| 东乌| 西城区| 连山| 武穴市| 光泽县| 壤塘县| 三江| 泽库县| 搜索| 扎囊县| 安阳县|