新聞中心
來(lái)源|https://dev.to/vorillaz/how-to-detect-idle-browser-tabs-with-javascript-88n

成都創(chuàng)新互聯(lián)公司主營(yíng)南陽(yáng)網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,成都App定制開發(fā),南陽(yáng)h5小程序定制開發(fā)搭建,南陽(yáng)網(wǎng)站營(yíng)銷推廣歡迎南陽(yáng)等地區(qū)企業(yè)咨詢
作者|vorillaz
在某些情況下,當(dāng)用戶與我們的最終產(chǎn)品或應(yīng)用程序進(jìn)行交互時(shí),我們發(fā)現(xiàn)自己會(huì)執(zhí)行許多密集的,占用大量CPU的任務(wù)。啟動(dòng)輪詢器,建立WebSocket連接,甚至加載視頻或圖片等媒體,都有可能成為性能障礙,尤其是當(dāng)這些任務(wù)在不需要的情況下消耗資源的時(shí)候。在用戶沒(méi)有主動(dòng)與界面交互的同時(shí),從不必要的工作負(fù)載或網(wǎng)絡(luò)請(qǐng)求中釋放主線程是一個(gè)非常好的和有意義的實(shí)踐。換一種方式,在大多數(shù)主機(jī)提供商都在引入基于配額的定價(jià)模式的行業(yè)中,減少網(wǎng)絡(luò)請(qǐng)求也可以降低運(yùn)行應(yīng)用程序或服務(wù)的成本。
目錄
- 頁(yè)面可見(jiàn)性(Page Visibility) API
- document.visibilityState
- visibilitychange Event
- 輪詢示例
- 在后臺(tái)異步加載
- Webpack
- Rollup
- 用Javascript預(yù)加載
- 微互動(dòng)
頁(yè)面可見(jiàn)性(Page Visibility) API
所有現(xiàn)代的網(wǎng)頁(yè)瀏覽器都加入了頁(yè)面可見(jiàn)性API,它允許我們檢測(cè)瀏覽器的標(biāo)簽頁(yè)何時(shí)被隱藏,此外,我們還可以注冊(cè)一個(gè)事件監(jiān)聽器,以檢測(cè)可見(jiàn)性變化時(shí)的信號(hào)。
document.visibilityState
當(dāng)頁(yè)面處于前臺(tái)時(shí),document.visibilityState 可能是 visible ,最小化窗口的“標(biāo)簽”或隱藏。
我們可以通過(guò)以下方式直接訪問(wèn) document.visibilityState:
- console.log(document.visibilityState);
- // => 它可以是“visible”或“hidden”
visibilitychange Event
我們還可以使用事件偵聽器輕松檢測(cè)可見(jiàn)性屬性中的更改。
- const onVisibilityChange = () => {
- if (document.visibilityState === 'hidden') {
- console.log('> 這個(gè)窗口是隱藏的.');
- } else {
- console.log('> 這個(gè)窗口是可見(jiàn)的.');
- }
- };
- document.addEventListener('visibilitychange', onVisibilityChange, false);
輪詢示例考慮一種情況,在這種情況下,我們正在輪詢API以獲取更新,并且希望避免對(duì)空閑用戶進(jìn)行不必要的調(diào)用。一個(gè)簡(jiǎn)化的示例如下所示:
- 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);
在后臺(tái)異步加載
但有時(shí)我們可以通過(guò)反其道而行之,加速用戶的終端體驗(yàn)。我們可以異步加載外部依賴或資產(chǎn),而不是取消所有的作業(yè)和請(qǐng)求。這樣,當(dāng)用戶回來(lái)時(shí),他們的最終體驗(yàn)將更加“充實(shí)”并且豐富。
Webpack
使用ES2015動(dòng)態(tài)導(dǎo)入建議和適當(dāng)?shù)腤ebpack配置清單,我們可以輕松地在后臺(tái)加載額外的模塊或資產(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還支持開箱即用的動(dòng)態(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來(lái)預(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);
微互動(dòng)
最后,一種吸引用戶注意力的巧妙方法是動(dòng)態(tài)更改圖標(biāo),只需使用幾個(gè)像素就可以保持交互。
- 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);
本文轉(zhuǎn)載自微信公眾號(hào)「前端全棧開發(fā)者」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系前端全棧開發(fā)者公眾號(hào)。
網(wǎng)站題目:使用JavaScript檢測(cè)空閑的瀏覽器選項(xiàng)卡,可以做些什么?
標(biāo)題URL:http://www.dlmjj.cn/article/dhsojoi.html


咨詢
建站咨詢
