欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

js前端怎樣寫一個(gè)精確的倒計(jì)時(shí)代碼

這篇文章給大家分享的是有關(guān)js前端怎樣寫一個(gè)精確的倒計(jì)時(shí)代碼的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

成都創(chuàng)新互聯(lián)主要從事網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)三都,十余年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792

原理

眾所周知 setTimeout 或者 setInterval 調(diào)用的時(shí)候會(huì)有微小的誤差。有人做了一個(gè) demo 來觀察這個(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è)備打開了網(wǎng)絡(luò)時(shí)間同步,也會(huì)解決這個(gè)問題。

但是,如果用戶修改了設(shè)備時(shí)間,那么整個(gè)倒計(jì)時(shí)就沒有意義了,用戶只要將設(shè)備時(shí)間修改為倒計(jì)時(shí)的 endTime 就可以輕易看到倒計(jì)時(shí)結(jié)束是頁面的變化。因此一開始獲取服務(wù)端時(shí)間就是很重要的。

簡(jiǎn)單的說,一個(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)確的問題

代碼

獲取剩余時(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

然后可以通過下面的方式來使用:

// 獲取服務(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)
})

這樣的的寫法也可以做到準(zhǔn)確倒計(jì)時(shí),同時(shí)也比較簡(jiǎn)潔。不需要隔段時(shí)間再去同步一次服務(wù)端時(shí)間。

補(bǔ)充

在寫倒計(jì)時(shí)的時(shí)候遇到了一個(gè)坑這里記錄一下。

千萬別在倒計(jì)時(shí)結(jié)束的時(shí)候請(qǐng)求接口。會(huì)讓服務(wù)端瞬間 QPS 峰值達(dá)到非常高。

js前端怎樣寫一個(gè)精確的倒計(jì)時(shí)代碼

如果在倒計(jì)時(shí)結(jié)束的時(shí)候要使用新的數(shù)據(jù)渲染頁面,正確的做法是:

在倒計(jì)時(shí)結(jié)束前的一段時(shí)間里,先請(qǐng)求好數(shù)據(jù),倒計(jì)時(shí)結(jié)束后,再渲染頁面。

感謝各位的閱讀!關(guān)于“js前端怎樣寫一個(gè)精確的倒計(jì)時(shí)代碼”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

新聞標(biāo)題:js前端怎樣寫一個(gè)精確的倒計(jì)時(shí)代碼
URL鏈接:http://chinadenli.net/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í)需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
偷拍美女洗澡免费视频| 久久精品色妇熟妇丰满人妻91 | 日本一本不卡免费视频 | 欧美日韩在线视频一区| 国产一二三区不卡视频| 色综合伊人天天综合网中文| 91麻豆视频国产一区二区| 久久精品偷拍视频观看| 久久99亚洲小姐精品综合| 东京热加勒比一区二区| 亚洲一区二区精品国产av| 日韩人妻少妇一区二区| 欧美激情区一区二区三区| 大香蕉伊人精品在线观看| 亚洲av日韩一区二区三区四区 | 国产精品大秀视频日韩精品| 日韩人妻一区二区欧美| 精品少妇人妻一区二区三区| 好东西一起分享老鸭窝| 日本午夜乱色视频在线观看| 老司机精品一区二区三区| 亚洲a码一区二区三区| 国产黄色高清内射熟女视频| 欧美日韩精品人妻二区三区| 久久精品中文字幕人妻中文 | 国产老熟女超碰一区二区三区| 欧美同性视频免费观看| 日韩欧美国产精品自拍| 久久国产精品热爱视频| 亚洲中文在线观看小视频| 国产一区欧美午夜福利| 欧美国产日本高清在线| 在线精品首页中文字幕亚洲| 欧美乱视频一区二区三区| 婷婷激情四射在线观看视频 | 97人妻精品一区二区三区男同| 99久久精品免费精品国产| 国产一级片内射视频免费播放| 国产三级视频不卡在线观看| 久久香蕉综合网精品视频| 日本精品视频一二三区|