真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何使用JavaScript檢測(cè)空閑的瀏覽器選項(xiàng)卡

今天就跟大家聊聊有關(guān)如何使用JavaScript檢測(cè)空閑的瀏覽器選項(xiàng)卡,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

成都創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括秦淮網(wǎng)站建設(shè)、秦淮網(wǎng)站制作、秦淮網(wǎng)頁(yè)制作以及秦淮網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,秦淮網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到秦淮省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

在某些情況下,當(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ù)的成本。

如何使用JavaScript檢測(cè)空閑的瀏覽器選項(xiàng)卡

頁(yè)面可見性(Page Visibility) API

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

const onVisibilityChange = () => {   if (document.visibilityState === 'hidden') {     console.log('> 這個(gè)窗口是隱藏的.');   } else {     console.log('> 這個(gè)窗口是可見的.');   } }; 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í)”并且豐富。

如何使用JavaScript檢測(cè)空閑的瀏覽器選項(xiàng)卡

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

看完上述內(nèi)容,你們對(duì)如何使用JavaScript檢測(cè)空閑的瀏覽器選項(xiàng)卡有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。


分享文章:如何使用JavaScript檢測(cè)空閑的瀏覽器選項(xiàng)卡
文章位置:http://weahome.cn/article/pcgcge.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部