91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Page?Visibility?API怎么使用

發布時間:2022-07-13 10:28:09 來源:億速云 閱讀:117 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“Page Visibility API怎么使用”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Page Visibility API怎么使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

一、簡介

有時候,開發者需要知道,用戶正在離開頁面。常用的方法是監聽下面三個事件。

pagehide

beforeunload

unload

但是,這些事件在手機上可能不會觸發,頁面就直接關閉了。因為手機系統可以將一個進程直接轉入后臺,然后殺死。

  • 用戶點擊了一條系統通知,切換到另一個 App。

  • 用戶進入任務切換窗口,切換到另一個 App。

  • 用戶點擊了 Home 按鈕,切換回主屏幕。

  • 操作系統自動切換到另一個 App(比如,收到一個電話)。

上面這些情況,都會導致手機將瀏覽器進程切換到后臺,然后為了節省資源,可能就會殺死瀏覽器進程。

以前,頁面被系統切換,以及系統清除瀏覽器進程,是無法監聽到的。開發者想要指定,任何一種頁面卸載情況下都會執行的代碼,也是無法做到的。為了解決這個問題,就誕生了 Page Visibility API。不管手機或桌面電腦,所有情況下,這個 API 都會監聽到頁面的可見性發生變化。

Page?Visibility?API怎么使用

這個新的 API 的意義在于,通過監聽網頁的可見性,可以預判網頁的卸載,還可以用來節省資源,減緩電能的消耗。比如,一旦用戶不看網頁,下面這些網頁行為都是可以暫停的。

  • 服務器的輪詢

  • 網頁動畫

  • 正在播放的音頻或視頻

二、document.visibilityState

這個 API 主要在document對象上,新增了一個document.visibilityState屬性。該屬性返回一個字符串,表示頁面當前的可見性狀態,共有三個可能的值。

hidden:頁面徹底不可見。

visible:頁面至少一部分可見。

prerender:頁面即將或正在渲染,處于不可見狀態。

其中,hidden狀態和visible狀態是所有瀏覽器都必須支持的。prerender狀態只在支持"預渲染"的瀏覽器上才會出現,比如 Chrome 瀏覽器就有預渲染功能,可以在用戶不可見的狀態下,預先把頁面渲染出來,等到用戶要瀏覽的時候,直接展示渲染好的網頁。

只要頁面可見,哪怕只露出一個角,document.visibilityState屬性就返回visible。只有以下四種情況,才會返回hidden

  • 瀏覽器最小化。

  • 瀏覽器沒有最小化,但是當前頁面切換成了背景頁。

  • 瀏覽器將要卸載(unload)頁面。

  • 操作系統觸發鎖屏屏幕。

可以看到,上面四種場景涵蓋了頁面可能被卸載的所有情況。也就是說,頁面卸載之前,document.visibilityState屬性一定會變成hidden

事實上,這也是設計這個 API 的主要目的。

另外,早期版本的 API,這個屬性還有第四個值unloaded,表示頁面即將卸載,現在已經被廢棄了。

注意,document.visibilityState屬性只針對頂層窗口,內嵌的<iframe>頁面的document.visibilityState屬性由頂層窗口決定。

使用 CSS 屬性隱藏<iframe>頁面(比如display: none;),并不會影響內嵌頁面的可見性。

三、document.hidden

由于歷史原因,這個 API 還定義了document.hidden屬性。該屬性只讀,返回一個布爾值,表示當前頁面是否可見。

document.visibilityState屬性返回visible時,document.hidden屬性返回false;其他情況下,都返回true

該屬性只是出于歷史原因而保留的,只要有可能,都應該使用document.visibilityState屬性,而不是使用這個屬性。

四、visibilitychange 事件

只要document.visibilityState屬性發生變化,就會觸發visibilitychange事件。

因此,可以通過監聽這個事件(通過document.addEventListener()方法或document.onvisibilitychange屬性),跟蹤頁面可見性的變化。

document.addEventListener('visibilitychange', function () {
  // 用戶離開了當前頁面
  if (document.visibilityState === 'hidden') {
    document.title = '頁面不可見';
  }
  // 用戶打開或回到頁面
  if (document.visibilityState === 'visible') {
    document.title = '頁面可見';
  }
});

上面代碼是 Page Visibility API 的最基本用法,可以監聽可見性變化。

下面是另一個例子,一旦頁面不可見,就暫停視頻播放。

var vidElem = document.getElementById('video-demo');
document.addEventListener('visibilitychange', startStopVideo);
function startStopVideo() {
  if (document.visibilityState === 'hidden') {
    vidElem.pause();
  } else if (document.visibilityState === 'visible') {
    vidElem.play();
  }
}

五、頁面卸載

下面專門討論一下,如何正確監聽頁面卸載。

頁面卸載可以分成三種情況。

  • 頁面可見時,用戶關閉 Tab 頁或瀏覽器窗口。

  • 頁面可見時,用戶在當前窗口前往另一個頁面。

  • 頁面不可見時,用戶或系統關閉瀏覽器窗口。

這三種情況,都會觸發visibilitychange事件。前兩種情況,該事件在用戶離開頁面時觸發;最后一種情況,該事件在頁面從可見狀態變為不可見狀態時觸發。

由此可見,visibilitychange事件比pagehidebeforeunloadunload事件更可靠,所有情況下都會觸發(從visible變為hidden)。因此,可以只監聽這個事件,運行頁面卸載時需要運行的代碼,不用監聽后面那三個事件。

甚至可以這樣說,unload事件在任何情況下都不必監聽,beforeunload事件只有一種適用場景,就是用戶修改了表單,沒有提交就離開當前頁面。另一方面,指定了這兩個事件的監聽函數,瀏覽器就不會緩存當前頁面。

讀到這里,這篇“Page Visibility API怎么使用”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

api
AI

平武县| 遂昌县| 万州区| 哈尔滨市| 乐陵市| 白城市| 镇江市| 巴彦淖尔市| 葫芦岛市| 通州区| 大庆市| 安多县| 怀宁县| 沙河市| 遂平县| 双江| 桂东县| 平安县| 东乌珠穆沁旗| 绥滨县| 衢州市| 邵阳市| 日喀则市| 延吉市| 巴彦县| 丰县| 柏乡县| 手游| 乐东| 苍溪县| 团风县| 浠水县| 青岛市| 繁峙县| 格尔木市| 攀枝花市| 永嘉县| 都匀市| 辽宁省| 麻城市| 新闻|