当前位置:首页 > JavaScript

js 实现倒计时

2026-01-12 13:13:59JavaScript

实现倒计时的基本方法

使用 JavaScript 实现倒计时可以通过 setIntervalsetTimeout 结合日期计算来完成。以下是两种常见实现方式。

使用 setInterval 实现倒计时

通过 setInterval 每秒更新倒计时显示,直到时间为零。

function startCountdown(targetTime, displayElement) {
  const countdownInterval = setInterval(() => {
    const now = new Date().getTime();
    const distance = targetTime - now;

    if (distance <= 0) {
      clearInterval(countdownInterval);
      displayElement.innerHTML = "倒计时结束";
      return;
    }

    const days = Math.floor(distance / (1000 * 60 * 60 * 24));
    const hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
    const minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60));
    const seconds = Math.floor((distance % (1000 * 60)) / 1000);

    displayElement.innerHTML = `${days}天 ${hours}小时 ${minutes}分钟 ${seconds}秒`;
  }, 1000);
}

// 示例用法
const targetTime = new Date("2024-12-31").getTime();
const displayElement = document.getElementById("countdown");
startCountdown(targetTime, displayElement);

使用 setTimeout 实现倒计时

通过递归调用 setTimeout 实现倒计时,避免 setInterval 可能带来的累积误差。

function updateCountdown(targetTime, displayElement) {
  const now = new Date().getTime();
  const distance = targetTime - now;

  if (distance <= 0) {
    displayElement.innerHTML = "倒计时结束";
    return;
  }

  const days = Math.floor(distance / (1000 * 60 * 60 * 24));
  const hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
  const minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60));
  const seconds = Math.floor((distance % (1000 * 60)) / 1000);

  displayElement.innerHTML = `${days}天 ${hours}小时 ${minutes}分钟 ${seconds}秒`;
  setTimeout(() => updateCountdown(targetTime, displayElement), 1000);
}

// 示例用法
const targetTime = new Date("2024-12-31").getTime();
const displayElement = document.getElementById("countdown");
updateCountdown(targetTime, displayElement);

优化倒计时显示

可以根据需求调整倒计时显示的格式,例如只显示小时、分钟和秒。

function formatTime(distance) {
  const hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
  const minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60));
  const seconds = Math.floor((distance % (1000 * 60)) / 1000);

  return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;
}

处理时区问题

如果倒计时涉及跨时区,建议使用 UTC 时间或明确指定时区。

js 实现倒计时

const targetTime = new Date("2024-12-31T00:00:00Z").getTime();

性能考虑

倒计时不需要高精度时,可以将更新频率调整为每秒一次。若需要更高精度,可以缩短间隔时间,但需注意性能影响。

标签: 倒计时js
分享给朋友:

相关文章

js实现vue路由

js实现vue路由

Vue路由基础实现 使用Vue Router实现前端路由需要先安装并配置路由库。Vue Router是Vue.js官方的路由管理器。 安装Vue Router: npm install vue-r…

js实现瀑布流

js实现瀑布流

实现瀑布流布局 瀑布流布局是一种常见的网页布局方式,常用于图片展示、商品列表等场景。以下是使用 JavaScript 实现瀑布流布局的几种方法。 纯 JavaScript 实现 通过计算元素的位置和…

js实现求导

js实现求导

实现数值求导的方法 在JavaScript中实现求导通常采用数值方法,因为JavaScript不是符号计算语言。以下是常见的数值微分方法: 中心差分法 中心差分法提供较高精度的导数近似: func…

js实现目录

js实现目录

实现目录的基本思路 在JavaScript中实现目录功能通常涉及以下几个核心步骤:解析文档中的标题元素(如h1-h6),动态生成目录结构,并添加交互逻辑(如点击跳转)。以下是具体实现方法: 解析标题…

节流js实现

节流js实现

节流(Throttle)的实现原理 节流是一种限制函数执行频率的技术,确保函数在一定时间间隔内最多执行一次。适用于高频触发事件(如滚动、输入、窗口调整等)的场景。 基础实现方式 使用时间戳判断是否执…

js实现正交

js实现正交

正交的概念 正交在数学和计算机科学中通常指两个向量垂直或线性无关。在编程中,正交性常被用于设计模块化、低耦合的系统。 向量正交判断 判断两个向量是否正交可以通过点积是否为0来实现: functio…