溫馨提示×

溫馨提示×

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

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

使用JavaScript檢測空閑的瀏覽器選項卡可以做些什么

發(fā)布時間:2021-09-30 14:53:05 來源:億速云 閱讀:132 作者:柒染 欄目:web開發(fā)

本篇文章為大家展示了使用JavaScript檢測空閑的瀏覽器選項卡可以做些什么,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

在某些情況下,當(dāng)用戶與我們的最終產(chǎn)品或應(yīng)用程序進行交互時,我們發(fā)現(xiàn)自己會執(zhí)行許多密集的,占用大量CPU的任務(wù)。啟動輪詢器,建立WebSocket連接,甚至加載視頻或圖片等媒體,都有可能成為性能障礙,尤其是當(dāng)這些任務(wù)在不需要的情況下消耗資源的時候。在用戶沒有主動與界面交互的同時,從不必要的工作負載或網(wǎng)絡(luò)請求中釋放主線程是一個非常好的和有意義的實踐。換一種方式,在大多數(shù)主機提供商都在引入基于配額的定價模式的行業(yè)中,減少網(wǎng)絡(luò)請求也可以降低運行應(yīng)用程序或服務(wù)的成本。

頁面可見性(Page Visibility)  API

所有現(xiàn)代的網(wǎng)頁瀏覽器都加入了頁面可見性API,它允許我們檢測瀏覽器的標簽頁何時被隱藏,此外,我們還可以注冊一個事件監(jiān)聽器,以檢測可見性變化時的信號。

document.visibilityState

當(dāng)頁面處于前臺時,document.visibilityState 可能是 visible  ,最小化窗口的“標簽”或隱藏。

我們可以通過以下方式直接訪問 document.visibilityState:

console.log(document.visibilityState); // => 它可以是“visible”或“hidden”

visibilitychange Event

我們還可以使用事件偵聽器輕松檢測可見性屬性中的更改。

const onVisibilityChange = () => {   if (document.visibilityState === 'hidden') {     console.log('> 這個窗口是隱藏的.');   } else {     console.log('> 這個窗口是可見的.');   } }; document.addEventListener('visibilitychange', onVisibilityChange, false);

輪詢示例考慮一種情況,在這種情況下,我們正在輪詢API以獲取更新,并且希望避免對空閑用戶進行不必要的調(diào)用。一個簡化的示例如下所示:

const poll = () => {   const interval = 1500;   let _poller = null;   const repeat = () => {     console.log(`~ Polling: ${Date.now()}.`);   };    return {     start: () => {       _poller = setInterval(repeat, interval);     },     stop: () => {       console.log('~ Poller stopped.');       clearInterval(_poller);     }   }; };  const poller = poll(); poller.start();  const onVisibilityChange = () => {   if (document.visibilityState === 'hidden') {     poller.stop();   } else {     poller.start();   } };  document.addEventListener('visibilitychange', onVisibilityChange, false);

在后臺異步加載

但有時我們可以通過反其道而行之,加速用戶的終端體驗。我們可以異步加載外部依賴或資產(chǎn),而不是取消所有的作業(yè)和請求。這樣,當(dāng)用戶回來時,他們的最終體驗將更加“充實”并且豐富。

Webpack

使用ES2015動態(tài)導(dǎo)入建議和適當(dāng)?shù)腤ebpack配置清單,我們可以輕松地在后臺加載額外的模塊或資產(chǎn)。

let loaded = false; const onVisibilityChange = () => {   if (document.visibilityState === 'hidden') {     // Aggresively preload external assets ans scripts     if (loaded) {       return;     }     Promise.all([       import('./async.js'),       import('./another-async.js'),       import(/* webpackChunkName: "bar-module" */ 'modules/bar'),       import(/* webpackPrefetch: 0 */ 'assets/images/foo.jpg')     ]).then(() => {       loaded = true;     });   } };  document.addEventListener('visibilitychange', onVisibilityChange, false);

Rollup

Rollup還支持開箱即用的動態(tài)導(dǎo)入。

let loaded = false; const onVisibilityChange = () => {   if (document.visibilityState === 'hidden') {     // Aggresively preload external assets ans scripts     if (loaded) {       return;     }     Promise.all([       import('./modules.js').then(({default: DefaultExport, NamedExport}) => {         // do something with modules.       })     ]).then(() => {       loaded = true;     });   } };  document.addEventListener('visibilitychange', onVisibilityChange, false);

用Javascript預(yù)加載

除了使用捆綁器,我們還可以僅使用幾行JavaScript來預(yù)加載靜態(tài)資源(例如圖像)。

let loaded = false;  const preloadImgs = (...imgs) => {   const images = [];   imgs.map(     url =>       new Promise((resolve, reject) => {         images[i] = new Image();         images[i].src = url;         img.onload = () => resolve();         img.onerror = () => reject();       })   ); };  const onVisibilityChange = () => {   if (document.visibilityState === 'hidden') {     // Aggresively preload external assets ans scripts     if (loaded) {       return;     }     Promise.all(       preloadImgs(         'https://example.com/foo.jpg',         'https://example.com/qux.jpg',         'https://example.com/bar.jpg'       )     )       .then(() => {         loaded = true;       })       .catch(() => {         console.log('> snap.');       });   } };  document.addEventListener('visibilitychange', onVisibilityChange, false);

微互動

最后,一種吸引用戶注意力的巧妙方法是動態(tài)更改圖標,只需使用幾個像素就可以保持交互。

const onVisibilityChange = () => {   const favicon = document.querySelector('[rel="shortcut icon"]');   if (document.visibilityState === 'hidden') {     favicon.href = '/come-back.png';   } else {     favicon.href = '/example.png';   } };  document.addEventListener('visibilitychange', onVisibilityChange, false);

上述內(nèi)容就是使用JavaScript檢測空閑的瀏覽器選項卡可以做些什么,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI