js之封装(秒数)转化为时分秒倒计时组件 vue版本

 

效果如上图;

<!-- * @Author: lhl * @Date: 2021-09-09 21:43:00 * @LastEditors: lhl * @LastEditTime: 2021-09-09 22:21:55 * @Description: 组件调用 <Test :remainTime="5000"></Test> --> <template> <span>{{ hour ? hourString + ':' + minuteString + ':' + secondString : minuteString + ':' + secondString }}</span> </template> <script> export default { data() { return { hour: '', minute: '', second: '', timer: '' } }, props: { remainTime: { // 倒计时间总秒数 default: '' } }, mounted() { if (this.remainTime > 0) { this.hour = Math.floor((this.remainTime / 3600) % 24) this.minute = Math.floor((this.remainTime / 60) % 60) this.second = Math.floor(this.remainTime % 60) this.countDowm() } else { this.minute = 0 this.second = 0 } }, methods: { countDowm() { var self = this clearInterval(this.timer) this.timer = setInterval(function () { if (self.hour === 0) { if (self.minute !== 0 && self.second === 0) { self.second = 59 self.minute -= 1 } else if (self.minute === 0 && self.second === 0) { self.second = 0 self.$emit('countDowmEnd', true) clearInterval(self.timer) } else { self.second -= 1 } } else { if (self.minute !== 0 && self.second === 0) { self.second = 59 self.minute -= 1 } else if (self.minute === 0 && self.second === 0) { self.hour -= 1 self.minute = 59 self.second = 59 } else { self.second -= 1 } } }, 1000) }, formatNum(num) { return num < 10 ? '0' + num : '' + num } }, computed: { hourString() { return this.formatNum(this.hour) }, minuteString() { return this.formatNum(this.minute) }, secondString() { return this.formatNum(this.second) } } } </script>

组件有不完善的地方请多多指出;多数场景自己已经测过了;

 


__EOF__

本文作者蓝色帅-橙子哥
本文链接https://www.cnblogs.com/lhl66/p/15249360.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   鱼樱前端  阅读(666)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
历史上的今天:
2017-09-09 vue移动端开发全家桶
 
大田后生仔 - 王雨萌
00:00 / 00:00
An audio error has occurred, player will skip forward in 2 seconds.
  1. 1 往后余生 王贰浪
  2. 2 拂雪 不才
  3. 3 我的一个道姑朋友 洛尘鞅
  4. 4 大田后生仔 王雨萌
点击右上角即可分享
微信分享提示