這篇文章給大家分享的是有關(guān)JS如何實(shí)現(xiàn)返回上一頁(yè)并刷新頁(yè)面的方法的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
我們一直強(qiáng)調(diào)成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)對(duì)于企業(yè)的重要性,如果您也覺(jué)得重要,那么就需要我們慎重對(duì)待,選擇一個(gè)安全靠譜的網(wǎng)站建設(shè)公司,企業(yè)網(wǎng)站我們建議是要么不做,要么就做好,讓網(wǎng)站能真正成為企業(yè)發(fā)展過(guò)程中的有力推手。專(zhuān)業(yè)的建站公司不一定是大公司,創(chuàng)新互聯(lián)建站作為專(zhuān)業(yè)的網(wǎng)絡(luò)公司選擇我們就是放心。
具體如下:
正常情況下我們通過(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è)面的話(huà),可以在上一頁(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)于“JS如何實(shí)現(xiàn)返回上一頁(yè)并刷新頁(yè)面的方法”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
分享名稱(chēng):JS如何實(shí)現(xiàn)返回上一頁(yè)并刷新頁(yè)面的方法
分享鏈接:http://aaarwkj.com/article16/pccegg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈、小程序開(kāi)發(fā)、網(wǎng)站設(shè)計(jì)、App開(kāi)發(fā)、品牌網(wǎng)站設(shè)計(jì)、企業(yè)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)