這篇文章給大家分享的是有關(guān)js前端怎樣寫(xiě)一個(gè)精確的倒計(jì)時(shí)代碼的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
成都創(chuàng)新互聯(lián)主要從事網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)三都,十余年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來(lái)電咨詢建站服務(wù):13518219792
原理
眾所周知 setTimeout 或者 setInterval 調(diào)用的時(shí)候會(huì)有微小的誤差。有人做了一個(gè) demo 來(lái)觀察這個(gè)現(xiàn)象并對(duì)其做了修正。短時(shí)間的誤差倒也可以接受,但是作為一個(gè)長(zhǎng)時(shí)間的倒計(jì)時(shí),誤差累計(jì)就會(huì)導(dǎo)致倒計(jì)時(shí)不準(zhǔn)確。
因此我們可以在獲取剩余時(shí)間的時(shí)候,每次 new 一個(gè)設(shè)備時(shí)間,因?yàn)樵O(shè)備時(shí)間的流逝相對(duì)是準(zhǔn)確的,并且如果設(shè)備打開(kāi)了網(wǎng)絡(luò)時(shí)間同步,也會(huì)解決這個(gè)問(wèn)題。
但是,如果用戶修改了設(shè)備時(shí)間,那么整個(gè)倒計(jì)時(shí)就沒(méi)有意義了,用戶只要將設(shè)備時(shí)間修改為倒計(jì)時(shí)的 endTime 就可以輕易看到倒計(jì)時(shí)結(jié)束是頁(yè)面的變化。因此一開(kāi)始獲取服務(wù)端時(shí)間就是很重要的。
簡(jiǎn)單的說(shuō),一個(gè)簡(jiǎn)單的精確倒計(jì)時(shí)原理如下:
初始化時(shí)請(qǐng)求一次服務(wù)器時(shí)間 serverTime,再 new 一個(gè)設(shè)備時(shí)間 deviceTime
deviceTime 與 serverTime 的差作為時(shí)間偏移修正
每次遞歸時(shí) new 一個(gè)系統(tǒng)時(shí)間,解決 setTimeout 不準(zhǔn)確的問(wèn)題
代碼
獲取剩余時(shí)間的代碼如下:
/** * 獲取剩余時(shí)間 * @param {Number} endTime 截止時(shí)間 * @param {Number} deviceTime 設(shè)備時(shí)間 * @param {Number} serverTime 服務(wù)端時(shí)間 * @return {Object} 剩余時(shí)間對(duì)象 */ let getRemainTime = (endTime, deviceTime, serverTime) => { let t = endTime - Date.parse(new Date()) - serverTime + deviceTime let seconds = Math.floor((t / 1000) % 60) let minutes = Math.floor((t / 1000 / 60) % 60) let hours = Math.floor((t / (1000 * 60 * 60)) % 24) let days = Math.floor(t / (1000 * 60 * 60 * 24)) return { 'total': t, 'days': days, 'hours': hours, 'minutes': minutes, 'seconds': seconds } }
獲取服務(wù)器時(shí)間可以使用 mtop 接口 mtop.common.getTimestamp
然后可以通過(guò)下面的方式來(lái)使用:
// 獲取服務(wù)端時(shí)間(獲取服務(wù)端時(shí)間代碼略) getServerTime((serverTime) => { //設(shè)置定時(shí)器 let intervalTimer = setInterval(() => { // 得到剩余時(shí)間 let remainTime = getRemainTime(endTime, deviceTime, serverTime) // 倒計(jì)時(shí)到兩個(gè)小時(shí)內(nèi) if (remainTime.total <= 7200000 && remainTime.total > 0) { // do something //倒計(jì)時(shí)結(jié)束 } else if (remainTime.total <= 0) { clearInterval(intervalTimer); // do something } }, 1000) })
這樣的的寫(xiě)法也可以做到準(zhǔn)確倒計(jì)時(shí),同時(shí)也比較簡(jiǎn)潔。不需要隔段時(shí)間再去同步一次服務(wù)端時(shí)間。
補(bǔ)充
在寫(xiě)倒計(jì)時(shí)的時(shí)候遇到了一個(gè)坑這里記錄一下。
千萬(wàn)別在倒計(jì)時(shí)結(jié)束的時(shí)候請(qǐng)求接口。會(huì)讓服務(wù)端瞬間 QPS 峰值達(dá)到非常高。
如果在倒計(jì)時(shí)結(jié)束的時(shí)候要使用新的數(shù)據(jù)渲染頁(yè)面,正確的做法是:
在倒計(jì)時(shí)結(jié)束前的一段時(shí)間里,先請(qǐng)求好數(shù)據(jù),倒計(jì)時(shí)結(jié)束后,再渲染頁(yè)面。
感謝各位的閱讀!關(guān)于“js前端怎樣寫(xiě)一個(gè)精確的倒計(jì)時(shí)代碼”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
新聞標(biāo)題:js前端怎樣寫(xiě)一個(gè)精確的倒計(jì)時(shí)代碼
URL鏈接:http://aaarwkj.com/article36/jeigpg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、、云服務(wù)器、全網(wǎng)營(yíng)銷推廣、網(wǎng)站收錄、品牌網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)