js和vue实现时分秒倒计时的方法

boyanx3个月前技术教程16

我们平常浏览网页的时候,经常见到“距游戏公测1天2小时3分钟4秒”这样的倒计时器。像切图网qietu.com经常就遇到要做倒计时的效果,干脆记录下来,免得重复造轮子。

下面两个 demo 将分别用纯 JavaScript 、基于 Vue.js 的 JavaScript 实现。代码中可能包含部分 ES6 语法,但相信很容易理解。

JavaScript
创建一个 countdown 方法,用于计算并在控制台打印距目标时间的日、时、分、秒数,每隔一秒递归执行一次。

msec 是当前时间距目标时间的毫秒数,由时间戳相减得到,我们将以这个数为基础计算。我们都知道1天等于24小时,1小时等于60分钟,1分钟等于60秒,1秒等于1000毫秒。所以,msec / 1000 / 60 / 60 / 24 保留整数就是天数。如果换用 % 取余数,再保留整数后得到的就是小时数。以此类推就能算出其他所有数。

function countdown () {
// 目标日期时间戳
const end = Date.parse(new Date(‘2017-12-01’))
// 当前时间戳
const now = Date.parse(new Date())
// 相差的毫秒数
const msec = end – now
// 计算时分秒数
let day = parseInt(msec / 1000 / 60 / 60 / 24)
let hr = parseInt(msec / 1000 / 60 / 60 % 24)
let min = parseInt(msec / 1000 / 60 % 60)
let sec = parseInt(msec / 1000 % 60)
// 个位数前补零
hr = hr > 9 ? hr : ‘0’ + hr
min = min > 9 ? min : ‘0’ + min
sec = sec > 9 ? sec : ‘0’ + sec
// 控制台打印
console.log(`${day}天 ${hr}小时 ${min}分钟 ${sec}秒`)
// 一秒后递归
setTimeout(function () {
countdown()
}, 1000)
}
控制台打印结果:

27天 07小时 49分钟 10秒
27天 07小时 49分钟 09秒
27天 07小时 49分钟 08秒

Vue.js
如果单纯使用 JavaScript ,我们需要在每次计算后手动更新 DOM 元素(将数据显示给用户),既不方便又难以维护。实际项目中更多的是配合前端框架,将计算结果实时渲染到页面上。

页面结构中的数据来自 Vue 实例的 data 对象。

<div id=”app”>{{ `${day}天 ${hr}小时 ${min}分钟 ${sec}分钟` }}</div>
mounted 是 Vue 的生命周期方法,可以理解为在页面加载完毕后执行 countdown 方法。countdown 方法每隔一秒会执行一次,并将计算结果分别赋予变量 day、hr、min、sec,同时改变的还有页面上显示的内容。

new Vue({
el: ‘#app’,
data: function () {
return {
day: 0, hr: 0, min: 0, sec: 0
}
},
mounted: function () {
this.countdown()
},
methods: {
countdown: function () {
const end = Date.parse(new Date(‘2017-12-01’))
const now = Date.parse(new Date())
const msec = end – now
let day = parseInt(msec / 1000 / 60 / 60 / 24)
let hr = parseInt(msec / 1000 / 60 / 60 % 24)
let min = parseInt(msec / 1000 / 60 % 60)
let sec = parseInt(msec / 1000 % 60)
this.day = day
this.hr = hr > 9 ? hr : ‘0’ + hr
this.min = min > 9 ? min : ‘0’ + min
this.sec = sec > 9 ? sec : ‘0’ + sec
const that = this
setTimeout(function () {
that.countdown()
}, 1000)
}
}
})
相关环境:Windows 7 x64 / Vue.js 2.4.4

标签: 倒计时代码

相关文章

用python打造一个简单的倒计时器

突发思维,可能是中考要考体育了,有这么一个想法,想搞一个计时器,二来也可以练习python代码。不知道有喜欢的么,头条君也不怎么给流量,就献给有缘人吧,学习代码是苦了点,总有很多人通过刻苦学到了不少...

【京张追光者:程序员爸爸的400公里温情代码】

凌晨6:00,张家口某小区车库亮起一道蓝光,93年程序员李航的智能手表自动开启「生存模式」——这是他在京张通勤路上迭代的第7版自研算法,正根据实时降雪预报、儿子足球赛倒计时、妻子体检报告三项数据,调整...

神秘代码

第五章 递归裂痕陈默的指尖触碰到缓冲凝胶时,水晶球体突然迸发出伽马射线暴。他翻滚着躲进操作台后方,看见自己刚才所在的位置被烧熔出冒着泡的岩浆坑。防护服在辐射中碳化剥落,怀表却在高温中显露出隐藏的晶格结...

第四章 天道代码!我在三十三天暴击创世神

天道往生殿的青铜门在业火中熔化,林默踏着云灼衣的红莲穿过门扉。虚空乱流撕扯着肉身,视网膜上跳动的暴击值突然扭曲成诡谲代码:【检测到本源规则】【暴击系统升级为创世模式】苏婉清背后的光翼片片剥落,焚天凤炎...

倒计时:11小时7分

艾登在沥青里呼吸。 他的鼻腔灌满冰冷的原油,却闻到1948年波本威士忌的味道。睁开眼时,自己正坐在老式巡逻车里,仪表盘泛着铜绿,后视镜挂着的十字架逆时针旋转。挡风玻璃外是黑白电影质感的街道,穿呢子大衣...

《末日代码》

核战倒计时第7小时,我破解了五角大楼的量子加密文件。"阻止发射的密码是...KFC-CRAZY-THURSDAY-VME50?"实验室的警报红光中,我盯着全息投影上的乱码。太平洋深处的...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。