不同设备上的JavaScript倒计时不同步
创始人
2025-01-09 15:34:46
0

解决"不同设备上的JavaScript倒计时不同步"的方法可以通过服务器时间同步和客户端时间校准来实现。以下是一个示例代码:

// 获取服务器时间
function getServerTime() {
  return new Promise((resolve, reject) => {
    // 发送一个AJAX请求,获取服务器时间
    // 例如:
    // fetch('/api/getServerTime')
    //   .then(response => response.json())
    //   .then(data => resolve(data.serverTime))
    //   .catch(error => reject(error));
  });
}

// 获取客户端时间
function getClientTime() {
  return new Date();
}

// 校准倒计时时间
function syncCountdownTime(serverTime, countdownTime) {
  const clientTime = getClientTime();
  const timeDifference = serverTime - clientTime;
  return new Date(countdownTime.getTime() + timeDifference);
}

// 倒计时逻辑
function countdown() {
  getServerTime()
    .then(serverTime => {
      const countdownTime = new Date('2022-01-01T00:00:00'); // 设定倒计时结束时间
      const adjustedCountdownTime = syncCountdownTime(serverTime, countdownTime);

      // 更新倒计时显示
      const interval = setInterval(() => {
        const currentTime = getClientTime();
        const remainingTime = adjustedCountdownTime - currentTime;

        // 如果倒计时结束
        if (remainingTime <= 0) {
          clearInterval(interval);
          console.log('倒计时结束');
        }
        
        // 更新倒计时显示,例如:
        // document.getElementById('countdown').innerText = formatRemainingTime(remainingTime);
      }, 1000);
    })
    .catch(error => console.error(error));
}

// 启动倒计时
countdown();

在上述代码中,getServerTime函数发送一个AJAX请求到服务器,获取服务器的时间。getClientTime函数获取客户端的时间。syncCountdownTime函数使用服务器时间和客户端时间的差异来校准倒计时时间。countdown函数使用校准后的倒计时时间来更新倒计时显示,并在倒计时结束时清除计时器。

请注意,上述代码只是一个示例,具体实现可能会根据实际需求有所不同。另外,为了保持倒计时的准确性,最好将服务器时间的获取和倒计时逻辑放在服务器端进行处理。

相关内容

热门资讯

德州之星插件!aa poker... 德州之星插件!aa poker辅助软件,德州ai能盈利(详细透视挂教程)科技教程也叫必备教程,这是一...
wepokeai机器人!wop... WePoker透视辅助工具核心要点解析‌,wepokeai机器人!wopoker辅助器ios,wep...
德州之星插件!德扑之星 ai软... 德州之星插件!德扑之星 ai软件,德州之星一贯是真的有挂(详细作弊教程)1、构建自己的微扑克辅助插件...
wpk有外 挂!wpk德州扑克... wpk有外 挂!wpk德州扑克线上,wpK原来真的有挂,详细教程,(有挂详情)1、许多玩家不知道wp...
aapoker俱乐部!wepo... aapoker俱乐部!wepower有辅助器,德州之星有辅助挂(详细透视挂教程)关于德州之星有辅助挂...
wepoke ai辅助!wep... wepoke ai辅助!wepoke可以来好牌,WEPOke一般真的有挂,科技教程(有挂介绍);原来...
德扑ai助手!wpk德州ai机... 德扑ai助手!wpk德州ai机器人,菠萝德州app真是是有挂(详细ai人工智能教程);德州ai机器人...
微扑克全自动机器人!wpk辅助... 微扑克全自动机器人!wpk辅助软件,wpk德州ai机器人(详细辅助教程);1.微扑克全自动机器人 a...
wpk外 挂(wpK)wpka... wpk外 挂(wpK)wpkai辅助(辅助挂)好像真的有挂(爆料教程)1、下载好wpk辅助软件之后点...
德州之星辅助挂!德扑人工智能软... 德州之星辅助挂!德扑人工智能软件,德州扑克总是真的有挂(详细微扑克辅助教程),亲,有的,ai轻松简单...