本文實例講述了JS實現返回上一頁并刷新頁面的方法。分享給大家供大家參考,具體如下:
正常情況下我們通過 history.back()
或者 history.go(-1)
返回上一級頁面的時候,是不會刷新頁面的。這種不刷新頁面包含兩種情況:
上網搜索 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頁面元素操作技巧總結》、《JavaScript操作DOM技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript錯誤與調試技巧總結》及《JavaScript數學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
新聞熱點
疑難解答