日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
如何使用JavaScript檢測空閑的瀏覽器選項(xiàng)卡

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

成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供橫峰網(wǎng)站建設(shè)、橫峰做網(wǎng)站、橫峰網(wǎng)站設(shè)計(jì)、橫峰網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、橫峰企業(yè)網(wǎng)站模板建站服務(wù),10余年橫峰做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

頁面可見性(Page Visibility) API

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

document.visibilityState

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

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

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

visibilitychange Event

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

 
 
 
 
  1. const onVisibilityChange = () => { 
  2.   if (document.visibilityState === 'hidden') { 
  3.     console.log('> 這個(gè)窗口是隱藏的.'); 
  4.   } else { 
  5.     console.log('> 這個(gè)窗口是可見的.'); 
  6.   } 
  7. }; 
  8. document.addEventListener('visibilitychange', onVisibilityChange, false); 

輪詢示例

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

 
 
 
 
  1. const poll = () => { 
  2.   const interval = 1500; 
  3.   let _poller = null; 
  4.   const repeat = () => { 
  5.     console.log(`~ Polling: ${Date.now()}.`); 
  6.   }; 
  7.  
  8.   return { 
  9.     start: () => { 
  10.       _poller = setInterval(repeat, interval); 
  11.     }, 
  12.     stop: () => { 
  13.       console.log('~ Poller stopped.'); 
  14.       clearInterval(_poller); 
  15.     } 
  16.   }; 
  17. }; 
  18.  
  19. const poller = poll(); 
  20. poller.start(); 
  21.  
  22. const onVisibilityChange = () => { 
  23.   if (document.visibilityState === 'hidden') { 
  24.     poller.stop(); 
  25.   } else { 
  26.     poller.start(); 
  27.   } 
  28. }; 
  29.  
  30. document.addEventListener('visibilitychange', onVisibilityChange, false); 

在后臺異步加載

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

/ Webpack /

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

 
 
 
 
  1. let loaded = false; 
  2. const onVisibilityChange = () => { 
  3.   if (document.visibilityState === 'hidden') { 
  4.     // Aggresively preload external assets ans scripts 
  5.     if (loaded) { 
  6.       return; 
  7.     } 
  8.     Promise.all([ 
  9.       import('./async.js'), 
  10.       import('./another-async.js'), 
  11.       import(/* webpackChunkName: "bar-module" */ 'modules/bar'), 
  12.       import(/* webpackPrefetch: 0 */ 'assets/images/foo.jpg') 
  13.     ]).then(() => { 
  14.       loaded = true; 
  15.     }); 
  16.   } 
  17. }; 
  18.  
  19. document.addEventListener('visibilitychange', onVisibilityChange, false); 

/ Rollup /

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

 
 
 
 
  1. let loaded = false; 
  2. const onVisibilityChange = () => { 
  3.   if (document.visibilityState === 'hidden') { 
  4.     // Aggresively preload external assets ans scripts 
  5.     if (loaded) { 
  6.       return; 
  7.     } 
  8.     Promise.all([ 
  9.       import('./modules.js').then(({default: DefaultExport, NamedExport}) => { 
  10.         // do something with modules. 
  11.       }) 
  12.     ]).then(() => { 
  13.       loaded = true; 
  14.     }); 
  15.   } 
  16. }; 
  17.  
  18. document.addEventListener('visibilitychange', onVisibilityChange, false); 

/ 用Javascript預(yù)加載 /

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

 
 
 
 
  1. let loaded = false; 
  2.  
  3. const preloadImgs = (...imgs) => { 
  4.   const images = []; 
  5.   imgs.map( 
  6.     url => 
  7.       new Promise((resolve, reject) => { 
  8.         images[i] = new Image(); 
  9.         images[i].src = url; 
  10.         img.onload = () => resolve(); 
  11.         img.onerror = () => reject(); 
  12.       }) 
  13.   ); 
  14. }; 
  15.  
  16. const onVisibilityChange = () => { 
  17.   if (document.visibilityState === 'hidden') { 
  18.     // Aggresively preload external assets ans scripts 
  19.     if (loaded) { 
  20.       return; 
  21.     } 
  22.     Promise.all( 
  23.       preloadImgs( 
  24.         'https://example.com/foo.jpg', 
  25.         'https://example.com/qux.jpg', 
  26.         'https://example.com/bar.jpg' 
  27.       ) 
  28.     ) 
  29.       .then(() => { 
  30.         loaded = true; 
  31.       }) 
  32.       .catch(() => { 
  33.         console.log('> Snap.'); 
  34.       }); 
  35.   } 
  36. }; 
  37.  
  38. document.addEventListener('visibilitychange', onVisibilityChange, false); 

微互動(dòng)

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

 
 
 
 
  1. const onVisibilityChange = () => { 
  2.   const favicon = document.querySelector('[rel="shortcut icon"]'); 
  3.   if (document.visibilityState === 'hidden') { 
  4.     favicon.href = '/come-back.png'; 
  5.   } else { 
  6.     favicon.href = '/example.png'; 
  7.   } 
  8. }; 
  9.  
  10. document.addEventListener('visibilitychange', onVisibilityChange, false); 

本文名稱:如何使用JavaScript檢測空閑的瀏覽器選項(xiàng)卡
網(wǎng)站地址:http://www.dlmjj.cn/article/djcdcog.html