js 倒計(jì)時(shí)(高效率服務(wù)器時(shí)間同步)
方案1:每次倒計(jì)時(shí)去服務(wù)端請(qǐng)求時(shí)間
//開啟定時(shí)器 var timer = setInterval(function () { //執(zhí)行請(qǐng)求,獲取當(dāng)前服務(wù)端時(shí)間并進(jìn)行相應(yīng)操作 }, 1000);
這個(gè)方案對(duì)于稍微有點(diǎn)經(jīng)驗(yàn)的開發(fā)人員來(lái)說(shuō),都知道是不可取的。因?yàn)檫@會(huì)給服務(wù)器造成無(wú)法想象的壓力,導(dǎo)致應(yīng)用崩潰。在這個(gè)頁(yè)面停留一分鐘,那么請(qǐng)求就發(fā)送了60次,假如此時(shí)有100個(gè)人在訪問這個(gè)頁(yè)面,那么一分鐘就有6000條請(qǐng)求,人數(shù)如果再增長(zhǎng),這絕對(duì)會(huì)造成不必要的服務(wù)器壓力。并且這個(gè)方案的倒計(jì)時(shí),也會(huì)存在很大的誤差,因?yàn)檎?qǐng)求存在延遲,跟你的網(wǎng)絡(luò)狀態(tài)也有很大的關(guān)系。
方案2:從服務(wù)端返回以服務(wù)器時(shí)間為基準(zhǔn)的倒計(jì)時(shí)時(shí)間戳
//開啟定時(shí)器 //假設(shè)請(qǐng)求獲取到一個(gè)時(shí)間戳?xí)r間差 dateDiff var timer = setInterval(function () { //每秒會(huì)獲取本地時(shí)間,這樣就算執(zhí)行的周期不準(zhǔn)確 也可以準(zhǔn)確的獲取時(shí)間差 var countDown = endTime - (+Date.now())/1000 + dateDiff; // 倒計(jì)時(shí)頁(yè)面渲染 }, 1000);
優(yōu)點(diǎn):
在頁(yè)面生命周期中請(qǐng)求一次
準(zhǔn)確度高,就算頁(yè)面打開很久還是保持高準(zhǔn)確度
缺點(diǎn):
由于每秒獲取當(dāng)前時(shí)間,假如刻意在倒計(jì)時(shí)時(shí)期內(nèi),修改了本地時(shí)間將會(huì)導(dǎo)致倒計(jì)時(shí)異常。
- 用JS寫了一個(gè)30分鐘倒計(jì)時(shí)器的實(shí)現(xiàn)示例
- js實(shí)現(xiàn)倒計(jì)時(shí)器自定義時(shí)間和暫停
- JS基于面向?qū)ο髮?shí)現(xiàn)的多個(gè)倒計(jì)時(shí)器功能示例
- JavaScript分秒倒計(jì)時(shí)器實(shí)現(xiàn)方法
- VB倒計(jì)時(shí)器和JS當(dāng)前時(shí)間
- JavaScript定時(shí)器設(shè)置、使用與倒計(jì)時(shí)案例詳解
- js定時(shí)器實(shí)現(xiàn)倒計(jì)時(shí)效果
- js實(shí)現(xiàn)瀏覽器倒計(jì)時(shí)跳轉(zhuǎn)頁(yè)面效果
- javascript同步服務(wù)器時(shí)間和同步倒計(jì)時(shí)小技巧
- JS實(shí)現(xiàn)簡(jiǎn)單網(wǎng)頁(yè)倒計(jì)時(shí)器
相關(guān)文章
基于Cesium實(shí)現(xiàn)拖拽3D模型的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何利用Cesium實(shí)現(xiàn)在地圖上添加一個(gè)3D模型,并且可以實(shí)現(xiàn)拖拽效果。文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-06-06BootStrap中Datetimepicker和uploadify插件應(yīng)用實(shí)例小結(jié)
這篇文章主要介紹了BootStrap中Datetimepicker和uploadify插件應(yīng)用實(shí)例小結(jié)的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-05-05微信小程序button標(biāo)簽open-type屬性原理解析
這篇文章主要介紹了微信小程序button標(biāo)簽open-type屬性原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01JS實(shí)現(xiàn)數(shù)組扁平化的方法分享
數(shù)組扁平化指的是:將一個(gè)多層嵌套的數(shù)組,處理成只有一層的數(shù)組。本文主要和大家介紹了幾個(gè)常用的JS數(shù)組扁平化方法,希望對(duì)大家有所幫助2023-04-04JavaScript轉(zhuǎn)換與解析JSON方法實(shí)例詳解
這篇文章主要介紹了JavaScript轉(zhuǎn)換與解析JSON方法,實(shí)例分析了JavaScript解析json的技巧,并附帶分析了jQuery解析與轉(zhuǎn)換json的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11