JS實(shí)現(xiàn)返回上一頁(yè)并刷新頁(yè)面的方法分析
本文實(shí)例講述了JS實(shí)現(xiàn)返回上一頁(yè)并刷新頁(yè)面的方法。分享給大家供大家參考,具體如下:
正常情況下我們通過 history.back()
或者 history.go(-1)
返回上一級(jí)頁(yè)面的時(shí)候,是不會(huì)刷新頁(yè)面的。這種不刷新頁(yè)面包含兩種情況:
- 在 android 或者 pc 瀏覽器中看到的頁(yè)面有刷新的效果,其實(shí)不是這樣的,這個(gè)時(shí)候的所有的資源都是從緩存中加載來的。我們通過瀏覽器調(diào)試工具可以看到 from disk cache 或者 from memory cache。
- 在 ios 中甚至于返回到了上一頁(yè)后,連上一頁(yè)的腳本文件都沒有執(zhí)行; (其實(shí)不是沒有執(zhí)行,是執(zhí)行了onpageshow)
上網(wǎng)搜索 ios 返回上一頁(yè)并刷新頁(yè)面的時(shí)候,會(huì)看到的解決方案有監(jiān)聽 onpageshow 事件, 通過查看文檔可以知道 onpageshow 事件中,可以通過使用 PageTransitionEvent 對(duì)象的 persisted 屬性來判斷,頁(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 的瀏覽器中沒有效果,經(jīng)過嘗試會(huì)發(fā)現(xiàn) android 和 pc 的瀏覽器中每一次進(jìn)入 pageshow事件后,event.persisted
永遠(yuǎn)都是返回 false。
不管是在任何情況下,都會(huì)監(jiān)聽到 pageshow事件。既然能進(jìn)入這個(gè)函數(shù),那就得想辦法在這個(gè)函數(shù)里判斷是否需要刷新頁(yè)面。可以通過緩存的方式 localStorage
或 sessionStorage
或 cookie
。
要在頁(yè)面中判斷是否需要刷新,那就得在從下一級(jí)返回過來的時(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)無限重載的情況
更多關(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車架號(hào)識(shí)別/驗(yàn)證函數(shù)代碼 汽車車架號(hào)驗(yàn)證程序
偶然中在CSDN里找到C#版的驗(yàn)證程序,因此改編了一版JS版本,相信會(huì)對(duì)大家有用2012-01-01javascript json字符串到j(luò)son對(duì)象轉(zhuǎn)義問題
今天小編就為大家分享一篇關(guān)于javascript json字符串到j(luò)son對(duì)象轉(zhuǎn)義問題,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01js 右鍵菜單,支持不同對(duì)象不同菜單(兼容IE、Firefox)
版本雖然很老也不符合標(biāo)準(zhǔn)了,不過代碼是值得參考的,需要右鍵菜單的朋友可以參考下。2010-01-01js實(shí)現(xiàn)繼承的方法及優(yōu)缺點(diǎn)總結(jié)
這篇文章主要給大家介紹了關(guān)于js實(shí)現(xiàn)繼承的方法及優(yōu)缺點(diǎn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05web3.js增加eth.getRawTransactionByHash(txhash)方法步驟
這篇文章主要介紹了web3.js增加eth.getRawTransactionByHash(txhash)方法步驟,需要的朋友可以參考下2018-03-03javascript權(quán)威指南 學(xué)習(xí)筆記之javascript數(shù)據(jù)類型
JavaScript中允許使用三種基本數(shù)據(jù)類型 數(shù)字,文本字符和布爾值。其中數(shù)字包括符點(diǎn)數(shù).此外,它還支持兩種小數(shù)據(jù)類型 -null(空)和undefined(未定義),該兩種小數(shù)據(jù)類型,它們各自只定義了一個(gè)值 。2011-09-09iframe父子頁(yè)面實(shí)現(xiàn)共用滾動(dòng)條的常見方法
在開發(fā)過程中,有時(shí)候需要用到iframe復(fù)用不同域名下的頁(yè)面內(nèi)容,為了提供連貫的用戶體驗(yàn),經(jīng)常需要在主頁(yè)面(父頁(yè)面)和iframe子頁(yè)面之間共享滾動(dòng)位置,本文將介紹其中較為常見的一種方法來實(shí)現(xiàn)iframe父子頁(yè)面共用滾動(dòng)條,需要的朋友可以參考下2024-05-05JavaScript 替換所有匹配內(nèi)容及正則替換方法
這篇文章主要介紹了JavaScript 替換所有匹配內(nèi)容,文中給大家提到了使用正則表達(dá)式替換方法,通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2020-02-02