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

首頁 > 開發 > JS > 正文

移動端H5頁面返回并刷新頁面(BFcache)的方法

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

項目中的需求:

點擊瀏覽器中的返回按鈕,要讓頁面重新加載資源。因為這部分的資源每次去加載的內容都不一樣,如果返回的時候,還是看到原先的內容,那做這個內容塊的意義就很小了;而如果用戶看完了這部分內容,再返回來的時候,這個地方換成了新的內容,這樣就能體現這部分的價值了。

而對于瀏覽器來說,大部分瀏覽器的返回是直接使用緩存的,不會執行任何的javascript代碼。原因:部分瀏覽器在后退時不會觸發onload事件,這是HTML5世代瀏覽器新增的特性之一——Back-Forward Cache(簡稱bfcache)

什么是bfcache?

bfcache,即back-forward cache,可稱為“往返緩存”,可以在用戶使用瀏覽器的“后退”和“前進”按鈕時加快頁面的轉換速度。這個緩存不僅保存頁面數據,還保存了DOM和JS的狀態,實際上是將整個頁面都保存在內存里。如果頁面位于bfcache中,那么再次打開該頁面就不會觸發onload事件

pageshow事件

這個事件在用戶瀏覽網頁時觸發,pageshow 事件類似于 onload 事件,onload 事件在頁面第一次加載時觸發, pageshow 事件在每次加載頁面時觸發,即 onload 事件在頁面從瀏覽器緩存中讀取時不觸發。

pagehide事件

該事件會在用戶離開網頁時觸發。離開網頁有多種方式。如點擊一個鏈接,刷新頁面,提交表單,關閉瀏覽器等。pagehide 事件有時可以替代 unload事件,但 unload 事件觸發后無法緩存頁面。

persisted屬性

pageshow事件和pagehide事件的event對象還包含一個名為persisted的布爾值屬性。

  對于pageshow事件,如果頁面是從bfcache中加載的,則這個屬性的值為true;否則,這個屬性的值為false。

  對于pagehide事件,如果頁面在卸載之后被保存在bfcache中,則這個屬性的值為true;否則,這個屬性的值為false。

不同的瀏覽器在對當前窗口‘打開'歷史記錄中的前一個頁面的表現上并不統一,這和瀏覽器的實現以及頁面本身的設置有關系。

解決方案:

javascript監聽pageshow事件阻止頁面進入bfcache

window.addEventListener('pageshow', function (e) {if (e.persisted) {window.location.reload()}})

在uc和微信中測試通過,但是在某些安卓手機自帶的瀏覽器中無效。

javascript監聽pagehide事件阻止頁面進入bfcache

window.addEventListener('pagehide', function (e) { var dom = document.body; dom.children.remove(); setTimeout(function () {  dom.appendChild("<script type='text/javascript'>window.location.reload();<//script>"); });});

設置meta標簽,清除頁面緩存

<meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate" /><meta http-equiv="Pragma" content="no-cache" /><meta http-equiv="Expires" content="0" />

Cache-Control指定請求和響應遵循的緩存機制。在請求消息或響應消息中設置Cache-Control并不會修改另一個消息處理過程中的緩存處理過程。請求時的緩存指令包括no-cache、no-store、max-age、max-stale、min-fresh、only-if-cached,響應消息中的指令包括public、private、no-cache、no-store、no-transform、must-revalidate、proxy-revalidate、max-age。各個消息中的指令含義如下

  • Public指示響應可被任何緩存區緩存
  • Private指示對于單個用戶的整個或部分響應消息,不能被共享緩存處理。這允許服務器僅僅描述當用戶的部分響應消息,此響應消息對于其他用戶的請求無效
  • no-cache指示請求或響應消息不能緩存
  • no-store用于防止重要的信息被無意的發布。在請求消息中發送將使得請求和響應消息都不使用緩存。
  • max-age指示客戶機可以接收生存期不大于指定時間(以秒為單位)的響應
  • min-fresh指示客戶機可以接收響應時間小于當前時間加上指定時間的響應
  • max-stale指示客戶機可以接收超出超時期間的響應消息。如果指定max-stale消息的值,那么客戶機可以接收超出超時期指定值之內的響應消息。

注:有些情況下設置清除緩存也沒有起到作用,我自己做的這個h5頁面就沒有起到效果。具體情況還是要具體分析。

我遇到的情況:

<div class="content"><iframe id="iframe" src="https://cpu.baidu.com/xx/xx/xxx" frameborder="no" scrolling="no"></iframe></div>

這個iframe中的地址每次刷新頁面都會有不同的內容推送給用戶。進入iframe中的內容之后,按返回按鈕返回來想進行頁面自動刷新,為的就是讓用戶看到新的內容。

做法:

使用pageshow進行整個頁面刷新

window.addEventListener('pageshow', function (e) {if (e.persisted) {window.location.reload()}})

這樣可以實現。

后面又覺得不妥,沒有因為這個小部分而進行整個頁面刷新,想到了另一種思路:因為這個iframe中的內容是動態的,可以對其進行定時器設置,如下:

let iframe = document.getElementById('iframe')setInterval(() => {iframe.setAttribute("src", "https://cpu.baidu.com/xx/xx/xx");},15000)

這樣也可以實現自己的功能。

最后可以結合一下:

let iframe = document.getElementById('iframe')window.addEventListener('pageshow', function (e) { if (e.persisted) {  iframe.setAttribute("src", "https://cpu.baidu.com/xx/xx/xx"); }})

這樣做也有好處,可以避免使用定時器,對網頁的性能也是比較好。但是這個方法在返回的時候,可以看到iframe里面內容的重新加載,會有一個時間間隙。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 内乡县| 靖边县| 东城区| 宁武县| 汨罗市| 彩票| 剑河县| 开阳县| 遂昌县| 德江县| 贺州市| 阜新市| 望都县| 图们市| 南江县| 铜梁县| 曲阜市| 沁阳市| 邵武市| 河北区| 邵阳县| 义马市| 原平市| 龙川县| 三原县| 梁山县| 岳阳市| 慈溪市| 乌拉特中旗| 西华县| 清新县| 利津县| 宜都市| 宜章县| 分宜县| 沐川县| 万全县| 昔阳县| 凤台县| 珠海市| 阿拉善左旗|