纯原生JS实现倒计时!

实现思路

目标时间 - 当前时间 = 剩余时间

当前时间

先计算当前时间用于显示证书打印日期,需要注意的是getMonth()的返回值需要加1才能得到实际的月份,因为它的索引值是从0到11。

另外getDate()getDay()要注意区分,后者是返回一周中的第几天(0代表周日)。

js 复制代码
let current = new Date(); // 获取到当前中国标准时间
let year = current.getFullYear(); // 获取年份
let month = current.getMonth() + 1; // 获取月份
let date = current.getDate(); // 获取日份

可以再完善一下,给月份和日份加个判断,如果它们的长度为1就在前面加个0。

js 复制代码
  if (String(month).length === 1) {
    month = "0" + month;
  }
  if (String(date).length === 1) {
    date = "0" + date;
  }

剩余时间

首先计算出剩余时间的毫秒数,再将毫秒分别转换为天、小时、分钟和秒。

js 复制代码
let target = new Date("2023/10/16 21:45:32"); // 设置域名过期时间
let currentTime = current.getTime(); // 获取当前时间戳
let targetTime = target.getTime(); // 获取目标时间戳
let remainingTime = targetTime - currentTime; // 计算剩余时间戳

let days = Math.floor(remainingTime / (1000 * 60 * 60 * 24)); // 天
let hours = Math.floor((remainingTime % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)); // 小时
let minutes = Math.floor((remainingTime % (1000 * 60 * 60)) / (1000 * 60)); // 分钟
let seconds = Math.floor((remainingTime % (1000 * 60)) / 1000); // 秒

出于美观考虑建议给它们前面都补个零,天数加不加都行。

js 复制代码
  if (String(hours).length === 1) {
    hours = "0" + hours;
  }
  if (String(minutes).length === 1) {
    minutes = "0" + minutes;
  }
  if (String(seconds).length === 1) {
    seconds = "0" + seconds;
  }

更新时间

封装一个updateCountdown()的函数,将以上代码包裹在内。

js 复制代码
function updateCountdown() {
...
}

开启setInterval计时器,设置每秒钟更新一次倒计时。

js 复制代码
let timer = setInterval(updateCountdown, 1000);

当剩余时间为0时清除定时器,一定要放到updateCountdown()里面才能更新倒计时。

js 复制代码
  if (remainingTime <= 0) {
    clearInterval(timer);
  }

最后,一个简单的倒计时就大功告成了!

相关推荐
MageGojo7 小时前
做节日活动页时,如何用 API 快速生成对联内容
javascript·python·节日·对联生成
向上的车轮7 小时前
Next.js 入门指南:从零到一构建全栈应用
开发语言·javascript·ecmascript
freeinlife'7 小时前
精准秒表计时器实现---基于js
开发语言·前端·javascript
优雅格子衫8 小时前
uniapp 拍照相册选取后超级好用的裁剪组件,增加水印完全自定义
开发语言·前端·javascript·uni-app·vue
AI砖家8 小时前
前端 JavaScript 异步处理全方案详解:从回调到 Observable
开发语言·前端·javascript
柒和远方8 小时前
每日一学V010: 从 Python 回到前端:一个 AI Native 开发者的 JavaScript 底层基础补全
javascript
之歆9 小时前
Day21_电商详情页核心技术实战:从LESS预处理到复杂交互实现
开发语言·前端·javascript·css·交互·less
海鸥两三9 小时前
基于 Vue 3 + 高德地图的网格规划系统实战(有源码)
前端·javascript·vue.js
逸A9 小时前
某里v2反混淆 codec 化路上踩到的两个隐蔽坑:被清零的 salt 与 opaque loop bound
javascript·人工智能·目标跟踪
丷丩9 小时前
MapLibre GL JS第11课:获取鼠标指针坐标
前端·javascript·gis·地图·mapbox·maplibre gl js