国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

監(jiān)聽微信返回事件踩坑指南

adam1q84 / 890人閱讀

摘要:瀏覽器返回等于重新進入上一個頁面,會觸發(fā)刷新動作,而微信不會。也就是困擾我多時的微信返回不刷新。也就是說當時微信返回還是會觸發(fā)渲染事件的具體是什么事件也不清楚,因為當時沒有深究,但是確實是觸發(fā)了。

PC瀏覽器返回等于重新進入上一個頁面,會觸發(fā)刷新動作,而微信不會。也就是困擾我多時的微信返回不刷新。

大概再2017年初和2016末(大概也是從那個時候我開始做微信公眾號),還可以通過在sessionStorage中記錄刷新標志,讓上一個頁面根據(jù)標識刷新。也就是說當時微信返回還是會觸發(fā)渲染事件的(具體是什么事件也不清楚,因為當時沒有深究,但是確實是觸發(fā)了componentDidMount)。

但是某個時刻起,這種方法也不再有效了,說明通過storage記錄需要刷新標志是完全失效的了。

另外可以發(fā)現(xiàn),上一個頁面會保持上一次操作的狀態(tài),并且不會再有靜態(tài)資源的請求,不會觸發(fā)load事件。那也可以這么理解,在微信中的頁面跳轉(zhuǎn),其實更類似于瀏覽器中的打開新標簽頁。所以上一個頁面的內(nèi)容沒有被銷掉,而是會保持你跳走前的狀態(tài)。所以我們很多頁面會有點擊返回但是loading還是在轉(zhuǎn)的現(xiàn)象。

嘗試一:visibilitychange

由此,我想到了第一個檢查他是否返回的方法——監(jiān)聽頁面的visibilitychange事件。因為PC瀏覽器中如果標簽切換或者是瀏覽器縮略,其可見性改變的時候,都會觸發(fā)該事件。

有興趣的可以打開控制臺輸入以下代碼,看看有什么不同。

window.addEventListener("visibilitychange", function () {
  console.log(document.hidden)
});

總之我先嘗試了以下代碼:

let isPageBack = false; 

window.addEventListener("visibilitychange", function () {
  if(document.hiden){ 
     isPageBack = true
 } else if ( isPageBack ) {
     fetch("/data") //因為visibilitychange事件中alert可以看到被模擬器禁了,所以就改用改了fetch自己的接口,通過查看日志檢查是否觸發(fā)
 }
});

嘗試之后發(fā)現(xiàn)該事件并沒有被觸發(fā)。疑惑之余,我嘗試了chrome手機瀏覽器,發(fā)現(xiàn)同樣,該事件沒有被觸發(fā)。

另外,因為好奇如果app壓后臺會不會觸發(fā)該事件,所以嘗試這段代碼↓,結(jié)果發(fā)現(xiàn)即使壓后臺頁面也不會被掛起。

setInterval(function () {
  var p = document.createElement("p");
  p.appendChild(document.createTextNode(`${Date.now()}`));
  document.body.appendChild(p);
}, 1000)
嘗試二:pageshow & pagehide

與visibilitychange類似的還有pageshowpagehide事件。

pageshow事件觸發(fā)點是 a session history entry is being traversed to. 同時根據(jù)MDN的介紹在back/forward時也會被觸發(fā)

于是我改了改代碼

let isPageBack = false;

window.addEventListener("pageshow", function () {
  if (isPageBack ) fetch("/data")
})

window.addEventListener("pagehide", function () {
  isPageBack = true
})

居然意外的能行,,,

pageshowpagehide事件可以被監(jiān)聽到。返回頁可以通過頁面是否隱藏過知道是否是返回回來的。

嘗試三:history

history可以修改歷史記錄或url主要是 history.pushStatehistory.replaceState

使用pushState 等于多推一條歷史記錄,replaceState 等于修改了歷史記錄,另外我們要知道reload是不計入歷史記錄的。

理論上來說如果使用pushState修改url,那么頁面訪問就會像這樣 A -> A1 -> B

當B返回A1時就會觸發(fā) popstate 事件。在popstate事件里面可以做一些自定義的事情。

這里用了代碼

 var state = {
   date: Date.now()
 };
 window.history.pushState(state, "csb");
 window.addEventListener("popstate", function (event) {
   if(event.state) location.reload()
 })

檢查history時,可以看到state里面有一個key是date的時間戳,同時歷史記錄的長度+1。
但是使用pushState會增加歷史記錄,會導致同一個頁面需要返回好幾次才能退出去,不過可以利用他做返回退出公眾號

window.history.pushState({}, "csb");
window.addEventListener("popstate", function (event) {
  if (event.state) { 
    wx.ready(function () {
      wx.closeWindow();
    });
  }
});


但是因為replaceState不會增加歷史記錄,所以利用它這樣返回刷新頁面

history.replaceState(null, null, "#");
window.addEventListener("popstate", function (event) {
 self.location.reload();
})

另外如果要如果A->B->C,而C返回時想要直接返回A可以這樣

B頁面:

history.replaceState(null, null, "/c"); //將url替換成C,這樣跳轉(zhuǎn)到C頁面等于被轉(zhuǎn)變成了reload行為,但直觀上來說,是我們刪除了一條歷史記錄

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/93290.html

相關(guān)文章

  • 微信小程序知識總結(jié)及案例集錦

    摘要:對微信小程序進行全局配置,決定頁面文件的路徑窗口表現(xiàn)設(shè)置網(wǎng)絡(luò)超時時間設(shè)置多等。 微信小程序知識總結(jié)及案例集錦 微信小程序的發(fā)展會和微信公眾號一樣,在某個時間點爆發(fā) 學習路徑 微信小程序最好的教程肯定是官方的文檔啦,點擊這里直達 微信官方文檔 認真跟著文檔看一遍,相信有vue前端經(jīng)驗的看下應(yīng)該就能上手了,然后安裝 微信小程序開發(fā)者工具 新建一個quick start項目,了解代碼結(jié)構(gòu),...

    sean 評論0 收藏0
  • Wepy-小程序踩坑

    摘要:引言用過原生開發(fā)的小程序也知道除了其他功能性的內(nèi)容并不多對于需要做大型項目來說是比較難入手的,因此朋友推薦的我就入坑鳥。。。開發(fā)還是和部分有出入,因此如下記錄,入手的教程就不發(fā)了只發(fā)踩坑。 引言 用過原生開發(fā)的小程序也知道除了api 其他功能性的內(nèi)容并不多對于需要做大型項目來說是比較難入手的,因此朋友推薦的wepy我就入坑鳥。。。這么一個跟vue的開發(fā)方式類似的框架,不過說起來跟vue...

    tinna 評論0 收藏0
  • H5視頻活動踩坑

    摘要:最近做了一些嵌入視頻的活動,積累了點視頻方面的經(jīng)驗,下面記錄下別人和自己踩過的坑以及相應(yīng)的解決方案。視頻的播放和暫停主要是調(diào)用和方法。最后需要注意的是在端播放視頻后是不會主動退出同層播放器的。 最近做了一些嵌入視頻的活動,積累了點視頻方面的經(jīng)驗,下面記錄下別人和自己踩過的坑以及相應(yīng)的解決方案。1、碰到問題和解決方案1.1、ios 網(wǎng)頁中播放視頻默認全屏(點擊視頻會彈出播放器進行全屏播放...

    walterrwu 評論0 收藏0
  • H5視頻活動踩坑

    摘要:最近做了一些嵌入視頻的活動,積累了點視頻方面的經(jīng)驗,下面記錄下別人和自己踩過的坑以及相應(yīng)的解決方案。視頻的播放和暫停主要是調(diào)用和方法。最后需要注意的是在端播放視頻后是不會主動退出同層播放器的。 最近做了一些嵌入視頻的活動,積累了點視頻方面的經(jīng)驗,下面記錄下別人和自己踩過的坑以及相應(yīng)的解決方案。1、碰到問題和解決方案1.1、ios 網(wǎng)頁中播放視頻默認全屏(點擊視頻會彈出播放器進行全屏播放...

    jzman 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<