成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

開發 前端
啟動輪詢器,建立WebSocket連接,甚至加載視頻或圖片等媒體,都有可能成為性能障礙,尤其是當這些任務在不需要的情況下消耗資源的時候。

 [[337673]]

來源|https://dev.to/vorillaz/how-to-detect-idle-browser-tabs-with-javascript-88n

作者|vorillaz

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

目錄

  • 頁面可見性(Page Visibility) API
  • document.visibilityState
  • visibilitychange Event
  • 輪詢示例
  • 在后臺異步加載
    • Webpack
    • Rollup
    • 用Javascript預加載
  • 微互動

頁面可見性(Page Visibility) API

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

document.visibilityState

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

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

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

visibilitychange Event

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

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

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

  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); 

在后臺異步加載

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

Webpack

使用ES2015動態導入建議和適當的Webpack配置清單,我們可以輕松地在后臺加載額外的模塊或資產。

  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還支持開箱即用的動態導入。

  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預加載

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

  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); 

微互動

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

  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); 

本文轉載自微信公眾號「前端全棧開發者」,可以通過以下二維碼關注。轉載本文請聯系前端全棧開發者公眾號。

 

責任編輯:武曉燕 來源: 前端全棧開發者
相關推薦

2020-05-28 08:33:28

JavaScript開發技術

2022-04-27 16:41:57

微軟Edge瀏覽器

2021-03-31 19:24:26

Edge微軟功能

2022-07-18 08:48:06

HtmxHTML

2020-12-25 06:56:11

Edge瀏覽器

2017-01-05 09:07:25

JavaScript瀏覽器驅動

2021-05-24 05:38:04

微軟Edge瀏覽器

2022-04-28 13:21:01

微軟Windows 11瀏覽器

2021-04-18 13:14:31

谷歌Chrome瀏覽器

2012-06-04 10:35:55

FirefoxChrome瀏覽器

2016-10-09 08:38:01

JavaScript瀏覽器事件

2020-10-20 09:38:29

微軟瀏覽器JavaScript

2020-03-12 11:29:51

JavaScript瀏覽器語言

2014-06-23 13:38:18

遨游瀏覽器

2023-07-28 00:19:35

2010-09-15 09:12:03

JavaScript瀏覽器兼容

2021-01-13 13:51:04

鴻蒙HarmonyOSTab選項卡

2009-03-23 08:52:51

2010-04-05 21:57:14

Netscape瀏覽器

2023-08-11 08:29:45

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人激情视频免费在线观看 | 国产偷久久一级精品60部 | 精品日韩在线观看 | 男人天堂色 | 国产污视频在线 | 99福利| 久久伊人亚洲 | 91精品国产乱码久久久久久久久 | 午夜精品网站 | 亚洲精品视频网站在线观看 | 亚洲精品成人在线 | 殴美成人在线视频 | 免费播放一级片 | 一级片在线播放 | 日本超碰 | 欧美 日韩 国产 成人 | 国产高清视频在线播放 | 国产91丝袜在线播放 | www.精品一区 | 日日摸日日碰夜夜爽2015电影 | 成人国产精品久久 | 日本成人福利 | 91久久精品一区二区二区 | 亚洲国产成人精品久久久国产成人一区 | 亚洲国产视频一区二区 | 精品久草 | 国产精品人人做人人爽 | 亚洲成av人片在线观看无码 | 国产一区二区 | 亚洲一区二区三区免费在线 | 久久久精| 天天色天天射天天干 | 日韩视频免费看 | 久久综合一区 | 中文欧美日韩 | 日本免费一区二区三区四区 | 久久99精品久久久久久琪琪 | 自拍偷拍一区二区三区 | 欧美区在线观看 | 午夜丰满寂寞少妇精品 | 成人在线免费观看 |