日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

如何使用JavaScript檢測空閑的瀏覽器選項卡

瀏覽:23日期:2023-06-20 17:54:29

在某些情況下,當用戶與我們的最終產品或應用程序進行交互時,我們發現自己會執行許多密集的,占用大量CPU的任務。啟動輪詢器,建立WebSocket連接,甚至加載視頻或圖片等媒體,都有可能成為性能障礙,尤其是當這些任務在不需要的情況下消耗資源的時候。

在用戶沒有主動與界面交互的同時,從不必要的工作負載或網絡請求中釋放主線程是一個非常好的和有意義的實踐。換一種方式,在大多數主機提供商都在引入基于配額的定價模式的行業中,減少網絡請求也可以降低運行應用程序或服務的成本。

如何使用JavaScript檢測空閑的瀏覽器選項卡

頁面可見性(Page Visibility) API

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

document.visibilityState

當頁面處于前臺時,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以獲取更新,并且希望避免對空閑用戶進行不必要的調用。一個簡化的示例如下所示:

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

在后臺異步加載

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

如何使用JavaScript檢測空閑的瀏覽器選項卡

/ Webpack /

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

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

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

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

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

微互動

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

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

總結

到此這篇關于如何使用JavaScript檢測空閑的瀏覽器選項卡的文章就介紹到這了,更多相關js瀏覽器選項卡內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲欧美高清| 樱桃成人精品视频在线播放| 国产精品88久久久久久| 国产精品黑丝在线播放| 中文字幕色婷婷在线视频| 91一区二区| 99久久99久久精品国产片果冰 | 久久国产乱子精品免费女| 一区二区三区四区在线观看国产日韩| 夜夜精品视频| 日韩高清在线不卡| 国产精品成人国产| 色婷婷亚洲mv天堂mv在影片| 特黄毛片在线观看| 日韩精品影视| 麻豆精品新av中文字幕| 色婷婷色综合| 久久国产精品久久w女人spa| 欧美专区一区二区三区| 亚洲深夜福利在线观看| 日韩视频在线一区二区三区 | 精品国产a一区二区三区v免费| 国产不卡人人| 午夜一级在线看亚洲| 久久国产精品免费精品3p| 日韩一区电影| 91亚洲国产| 国产亚洲精品v| 久久久国产精品入口麻豆| 99精品美女| 国产一精品一av一免费爽爽| 欧洲av不卡| 婷婷久久免费视频| 久久一区二区三区喷水| 视频一区日韩精品| 国产精品mm| 视频一区免费在线观看| 国产一区丝袜| 中文字幕一区二区三区在线视频| 国产精品115| 一区二区亚洲视频| 久久精品影视| 国产精品嫩模av在线| 快she精品国产999| 久久黄色影院| 成人午夜在线| 国产精品亚洲综合在线观看| 国产亚洲亚洲| 久久精品国产www456c0m| 国产精品中文字幕制服诱惑| 欧美 日韩 国产精品免费观看| 老司机精品视频网| 欧美日韩91| 日韩国产欧美在线视频| 亚洲视频电影在线| 免费在线观看成人| 欧美日韩四区| 狠狠干综合网| 水蜜桃久久夜色精品一区的特点| 四虎884aa成人精品最新| 久久精品国产精品亚洲毛片| 亚洲aa在线| 日本不卡高清| 久久精品超碰| 国产欧美日韩一级| 免费日韩视频| 亚洲免费福利一区| 日韩在线麻豆| 日本成人中文字幕在线视频| 日韩高清三区| 久久亚洲黄色| 日本美女一区| 欧美午夜不卡影院在线观看完整版免费| 久久人人88| 中文字幕日本一区| 久久国际精品| 国产精品毛片久久| 久久精品1区| 老牛影视一区二区三区| 国产日韩欧美中文在线| 国产亚洲精品精品国产亚洲综合| 国产欧美自拍| 伊人久久在线| 亚洲三级毛片| 欧美gv在线| 亚洲精品日本| 91日韩免费| 亚洲久久一区| 日韩欧美午夜| 亚洲精品九九| 久久精品高清| 久久精品一区二区国产| 久久五月天小说| 欧美aaaaaa午夜精品| 久久国产毛片| 日韩高清不卡在线| 欧美日韩国产高清电影| 国产精品sm| 免费在线欧美视频| 一区二区精品伦理...| 伊人国产精品| 久久人人88| 日韩av在线播放网址| 欧美一区91| 亚洲综合另类| 欧美1区免费| 久久免费福利| 欧美片网站免费| 日av在线不卡| 中文一区在线| 樱桃视频成人在线观看| 国产精品亚洲综合在线观看| 宅男噜噜噜66国产日韩在线观看| 国产一区二区三区国产精品| 亚洲午夜免费| 亚洲综合国产| 蘑菇福利视频一区播放| 久久精品中文| 一区二区小说| 99久久亚洲精品蜜臀| 国产一区二区三区不卡av| 久久国产视频网| 日韩激情一区二区| 日韩极品在线观看| 欧美日韩午夜电影网| 丝袜国产日韩另类美女| 久久亚洲成人| 91精品观看| 亚洲一卡久久| 日韩精品高清不卡| 欧美日韩精品一区二区三区在线观看| 综合一区av| 国产精品三级| 国产白浆在线免费观看| 色综合www| 国产亚洲综合精品| 天堂va在线高清一区| 国产日产精品一区二区三区四区的观看方式| 日韩欧美另类中文字幕| 国产精品一页| 久久免费视频66| 波多野结衣一区| 今天的高清视频免费播放成人| 亚洲精品在线二区| 久久丁香四色| 最新国产拍偷乱拍精品| 国产一区视频在线观看免费| 91久久中文| 国产欧美日韩精品一区二区免费| 久久福利在线| 欧美精品激情| 国产精品久久久久久模特| 国产色播av在线| 中文字幕日本一区二区| 天堂va欧美ⅴa亚洲va一国产| 亚洲大全视频| 欧美日韩伊人| 欧美日韩国产在线观看网站| 亚洲精品一级| 亚洲人成在线网站| 日本亚洲最大的色成网站www| 日韩综合一区| 日韩欧美中文在线观看| 国产a亚洲精品| 日韩精品五月天| 久久精品一区二区不卡| 欧美日韩一区自拍| 国产精品美女久久久| 精品一区二区三区视频在线播放| 亚洲在线观看| 久久亚洲精精品中文字幕| 蜜臀精品一区二区三区在线观看| 国产精品久久久久久久久妇女| 中文字幕亚洲影视| 日韩一区二区在线免费| 91成人在线网站| 午夜在线视频一区二区区别| 成人污污视频| 国产日韩欧美一区二区三区在线观看 | 精品国产午夜| 日韩三级视频| 亚洲激情中文在线| 亚洲高清毛片| 精品国产乱码久久久久久1区2匹| 亚洲资源网站| 另类亚洲自拍| 在线综合亚洲| 美女精品网站| 中文字幕中文字幕精品| 免费日韩av片| 天堂av在线一区| 免费人成网站在线观看欧美高清| 欧美中文一区二区| 99久久久久国产精品| 久久一区二区三区电影| 99精品一区| 一区视频在线| 中文无码久久精品| 激情丁香综合| 伊人久久大香线蕉av不卡|