通过vue2写个倒计时
时间: 2023-10-09 14:10:48 浏览: 90
Vue写一个简单的倒计时按钮功能
5星 · 资源好评率100%
好的,我可以为您提供一些关于Vue2倒计时的基本知识和代码实现。倒计时可以用于电商活动、促销倒计时、秒杀倒计时等场景。
Vue2倒计时有多种实现方式,以下是其中一种基础的实现方法:
1.在Vue组件中声明一个倒计时相关的状态变量
data() {
return {
targetTime: new Date('2022-01-01 00:00:00').getTime(),
//设置倒计时结束时间(如2022年1月1日)
nowTime: new Date().getTime(),
//设置当前时间
timeDiff: 0,
//设置时间差
timer: null,
//设置计时器变量
day: 0,
hour: 0,
minute: 0,
second: 0,
//设置显示的天、时、分、秒
}
}
2.创建一个方法,用于计算时间差、并更新显示的天、时、分、秒
methods: {
updateTime () {
this.nowTime = new Date().getTime();
this.timeDiff = this.targetTime - this.nowTime;
if (this.timeDiff <= 0) {
//倒计时结束,清除计时器
clearInterval(this.timer);
return;
}
//计算并更新显示的天、时、分、秒
this.day = Math.floor(this.timeDiff / 86400000);
this.hour = Math.floor((this.timeDiff % 86400000) / 3600000);
this.minute = Math.floor((this.timeDiff % 3600000) / 60000);
this.second = Math.floor((this.timeDiff % 60000) / 1000);
}
}
3.在Vue组件中创建生命周期函数mounted(),开启计时器
mounted() {
this.timer = setInterval(() => {
this.updateTime();
}, 1000);
}
4.在Vue组件中添加HTML代码,用于显示倒计时结果
<div>
<span>{{day}}</span>天
<span>{{hour}}</span>时
<span>{{minute}}</span>分
<span>{{second}}</span>秒
</div>
以上就是一个基础的Vue2倒计时实现方法。您也可以根据需要自定义样式、添加倒计时结束后的回调函数等。希望对您有所帮助。
阅读全文