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

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

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

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

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

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

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

頁面可見性(Page Visibility) API

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

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

在后臺異步加載

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

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

/ Webpack /

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

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)導入。

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來預加載靜態(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);

總結

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

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产乱人伦精品一区| 久久国际精品| 红桃视频国产一区| 色综合www| 亚洲www啪成人一区二区| 久久狠狠久久| 国产欧美日本| 欧美在线看片| 精品国产一区二区三区av片| 国产精品蜜月aⅴ在线| 亚洲精品日本| 国产精品天天看天天狠| 国产精品夜夜夜| 精品久久久久久久| 日韩在线欧美| 日韩视频精品在线观看| 日韩在线a电影| 91精品国产自产观看在线| 国产欧美另类| 裤袜国产欧美精品一区| 日韩影院二区| 亚洲视频二区| 日韩在线麻豆| 国产精品日韩久久久| 麻豆精品av| 国产精品三p一区二区| 久久久成人网| 福利视频一区| 精品视频免费| 国产精品第十页| 日韩国产欧美在线播放| 日韩久久精品| 国产精品成人国产| 亚洲18在线| 丝袜av一区| 日韩av一区二区三区| www在线观看黄色| 日本免费在线视频不卡一不卡二| 亚洲1234区| 国产精品久久久免费| 蜜桃av一区二区在线观看| 欧美日韩尤物久久| 国产精品2区| 亚洲毛片在线| 一区二区高清| 亚洲一区二区动漫| 一区在线视频观看| 欧美午夜不卡影院在线观看完整版免费| 樱桃视频成人在线观看| 久久av资源| 日韩在线第七页| 亚洲区国产区| 日韩av一级| 国产一区二区视频在线看| 日韩高清成人在线| 欧美精品资源| 玖玖玖国产精品| 亚州欧美在线| 久久三级福利| 精品午夜视频| 日韩精品第二页| 欧美一级一区| 国产乱人伦精品一区| 日本伊人久久| 日本国产亚洲| 亚洲精品一区二区在线播放∴| 99在线精品免费视频九九视| 国产亚洲精品v| 综合激情视频| 国产亚洲精品美女久久| 国产欧美亚洲精品a| 久久亚洲精精品中文字幕| 美女国产精品久久久| 国产在线看片免费视频在线观看| 在线天堂中文资源最新版| 欧美日韩免费观看一区=区三区| 老牛影视一区二区三区| 综合在线一区| 91欧美极品| 精品中国亚洲| 日韩1区在线| 国精品一区二区三区| 蜜臀va亚洲va欧美va天堂| 欧美黄色一区二区| 岛国av在线播放| av资源亚洲| 日韩午夜av| 欧美国产另类| 99pao成人国产永久免费视频 | 国产精品黑丝在线播放| 日韩视频久久| 精品久久久中文字幕| 亚洲一区二区三区高清不卡| 亚洲精品影视| av免费不卡国产观看| 成人国产精品久久| 精品亚洲美女网站| 天堂va在线高清一区| 日韩伦理在线一区| 亚洲一区有码| 国产成人精选| 午夜久久av | 国产亚洲精品精品国产亚洲综合| 欧美国产精品| 亚洲免费高清| 99久久九九| 久久影院一区二区三区| 深夜福利亚洲| 久久不射中文字幕| 涩涩av在线| 久久精品不卡| 欧美在线首页| 久久久噜噜噜| 日本午夜精品久久久| 国产精品日本欧美一区二区三区| 日本а中文在线天堂| 亚洲日本久久| 欧美日韩中文字幕一区二区三区| 国产欧美在线| 亚洲天堂免费| 蜜臀av在线播放一区二区三区| 天堂√中文最新版在线| 卡一精品卡二卡三网站乱码| 亚洲精品日韩久久| 在线看片日韩| 蜜桃av一区二区| 亚洲欧美在线综合| 免费观看日韩电影| 午夜精品免费| 日韩视频一区| 中文字幕一区二区三区四区久久 | 日本一区二区高清不卡| 911亚洲精品| 播放一区二区| 99精品视频在线观看免费播放| 中文一区一区三区高中清不卡免费| 国产伦精品一区二区三区在线播放| 天堂av一区| 国产欧美日韩精品一区二区三区| 国产精品白浆| 久久精品国产99国产精品| 久久在线91| 久久婷婷亚洲| 国产精品一区亚洲| 亚洲一区日韩在线| 久久香蕉网站| 激情五月综合| 亚洲精品无吗| 欧美激情久久久久久久久久久| 久久美女精品| 精品欧美日韩精品| 亚洲精品福利| 午夜一级久久| 亚洲伦乱视频| 国产一区二区三区不卡视频网站 | 免费亚洲一区| 石原莉奈一区二区三区在线观看 | 亚洲成人精选| 国产乱子精品一区二区在线观看| 人在线成免费视频| 欧美在线首页| 香蕉久久久久久久av网站| 久久精品国产网站| 久久国内精品| 日韩激情啪啪| 国产二区精品| 日韩毛片视频| 国产极品一区| 欧美日韩网址| 久久香蕉国产| 国产精品激情电影| 激情欧美丁香| 精品视频国内| 亚洲精品无吗| 国产国产精品| 国产欧美一区二区三区精品酒店| 岛国精品一区| 欧美1区二区| 国产极品一区| 国产精品毛片久久| 精品国产鲁一鲁****| 综合亚洲视频| 国产亚洲一卡2卡3卡4卡新区| 婷婷精品在线观看| 免费欧美在线视频| 日韩二区三区在线观看| 青青青国产精品| 国产欧美自拍| 久久gogo国模啪啪裸体| 国产精品一区二区三区www| 伊人久久大香线蕉av超碰演员| 精品一区二区三区亚洲| 国产色综合网| 久久精品不卡| 电影亚洲精品噜噜在线观看| 国产日产高清欧美一区二区三区 | 亚洲精品在线a| 香蕉久久久久久| 亚洲欧美一级| 国产精品片aa在线观看|