JS實(shí)現(xiàn)返回上一頁(yè)并刷新頁(yè)面的方法分析
本文實(shí)例講述了JS實(shí)現(xiàn)返回上一頁(yè)并刷新頁(yè)面的方法。分享給大家供大家參考,具體如下:
正常情況下我們通過(guò) history.back() 或者 history.go(-1) 返回上一級(jí)頁(yè)面的時(shí)候,是不會(huì)刷新頁(yè)面的。這種不刷新頁(yè)面包含兩種情況:
- 在 android 或者 pc 瀏覽器中看到的頁(yè)面有刷新的效果,其實(shí)不是這樣的,這個(gè)時(shí)候的所有的資源都是從緩存中加載來(lái)的。我們通過(guò)瀏覽器調(diào)試工具可以看到 from disk cache 或者 from memory cache。
- 在 ios 中甚至于返回到了上一頁(yè)后,連上一頁(yè)的腳本文件都沒(méi)有執(zhí)行; (其實(shí)不是沒(méi)有執(zhí)行,是執(zhí)行了onpageshow)
上網(wǎng)搜索 ios 返回上一頁(yè)并刷新頁(yè)面的時(shí)候,會(huì)看到的解決方案有監(jiān)聽(tīng) onpageshow 事件, 通過(guò)查看文檔可以知道 onpageshow 事件中,可以通過(guò)使用 PageTransitionEvent 對(duì)象的 persisted 屬性來(lái)判斷,頁(yè)面是直接從服務(wù)器上載入還是從緩存中讀??; 如果頁(yè)面從瀏覽器的緩存中讀取該屬性返回 ture,否則返回 false。
在 ios 中如果要實(shí)現(xiàn),返回上一頁(yè)并刷新頁(yè)面的話,可以在上一頁(yè)的腳本文件中加入如下代碼:
window.addEventListener('pageshow', function(event) {
if(event.persisted) { // ios 有效, android 和 pc 每次都是 false
sessionStorage.removeItem('refresh');
location.reload();
}
});
但是這種方式在 android 和 pc 的瀏覽器中沒(méi)有效果,經(jīng)過(guò)嘗試會(huì)發(fā)現(xiàn) android 和 pc 的瀏覽器中每一次進(jìn)入 pageshow事件后,event.persisted 永遠(yuǎn)都是返回 false。
不管是在任何情況下,都會(huì)監(jiān)聽(tīng)到 pageshow事件。既然能進(jìn)入這個(gè)函數(shù),那就得想辦法在這個(gè)函數(shù)里判斷是否需要刷新頁(yè)面??梢酝ㄟ^(guò)緩存的方式 localStorage 或 sessionStorage 或 cookie。
要在頁(yè)面中判斷是否需要刷新,那就得在從下一級(jí)返回過(guò)來(lái)的時(shí)候,往 cache中存入需要刷新。
sessionStorage.setItem('refresh', 'true');
history.go(-1);
然后在上一級(jí)也頁(yè)面獲取并判斷
if(sessionStorage.getItem('refresh') === 'true') {
sessionStorage.removeItem('refresh');
location.reload();
}
綜合兼容所有設(shè)備的返回上一頁(yè)并刷新頁(yè)面的方式為:
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. 在下一級(jí)頁(yè)面返回的時(shí)候,要標(biāo)記需要刷新頁(yè)面(set)
2. 在判斷完成后,一定要?jiǎng)h除之前的存儲(chǔ)(remove)避免出現(xiàn)無(wú)限重載的情況
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript頁(yè)面元素操作技巧總結(jié)》、《JavaScript操作DOM技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
JavaScript中的Map數(shù)據(jù)結(jié)構(gòu)詳解
這篇文章主要為大家介紹了JavaScript的Map數(shù)據(jù)結(jié)構(gòu),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-01-01
JavaScript console的使用方法實(shí)例分析
這篇文章主要介紹了JavaScript console的使用方法,結(jié)合實(shí)例形式分析了JavaScript console的使用方法與操作注意事項(xiàng),需要的朋友可以參考下2020-04-04
JavaScript之DOM_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
由于HTML文檔被瀏覽器解析后就是一棵DOM樹(shù),要改變HTML的結(jié)構(gòu),就需要通過(guò)JavaScript來(lái)操作DOM。始終記住DOM是一個(gè)樹(shù)形結(jié)構(gòu)。2017-07-07
Jquery實(shí)現(xiàn)的tab效果可以指定默認(rèn)顯示第幾頁(yè)
tab效果想必大家在網(wǎng)上都有見(jiàn)過(guò)很多吧,在本文將為大家介紹下如何實(shí)現(xiàn)可以在代碼里面指定默認(rèn)顯示第幾頁(yè)的tab效果,感興趣的朋友不要錯(cuò)過(guò)2013-10-10
純JavaScript 實(shí)現(xiàn)flappy bird小游戲?qū)嵗a
這篇文章主要介紹了純JavaScript 實(shí)現(xiàn)flappy bird小游戲?qū)嵗a,b本文分七大步驟給大家介紹,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
JavaScript-html標(biāo)題滾動(dòng)效果的簡(jiǎn)單實(shí)現(xiàn)
下面小編就為大家?guī)?lái)一篇JavaScript-html標(biāo)題滾動(dòng)效果的簡(jiǎn)單實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09
JavaScript分水嶺CommonJS對(duì)比ES模塊分析
這篇文章主要為大家介紹了JavaScript分水嶺CommonJS對(duì)比ES模塊分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11
js中document.getElementById(id)的具體用法
本文主要介紹了js中document.getElementById(id)的具體用法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04

