本篇内容主要讲解“vue怎么实现简易计时器组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue怎么实现简易计时器组件”吧!
在做项目中难免会碰到需要实时刷新,广告动画依次出现等等需求,刚最近基于业务需求,需要实现一个累加通话时长的计时器,这时候就需要定时器登上我们的代码舞台了,其实对于计时器,它的原理就是通过定时器来实现的,那么在写业务需求之前,我先说说关于定时器的一些知识。
window对象提供了两个方法来实现定时器的效果,分别是window.setTimeout()和window.setInterval。
在Javascript中,代码一般都是同步执行的,但定时器却是异步执行的。
window.setTimeout(callback,delay); //callback:回调函数 delay:时间间隔时长
window.setInterval(callback,delay);
定时器分为隔时定时器setInterval和延时定时器setTimeout
那么它们两到底有什么区别呢?
setInterval以指定时间为周期循环执行,一般用于刷新表单、复杂动画的循环执行,对于一些表单的实时指定时间刷新同步
setTimeout只在指定时间后执行一次,像有些网站刚进去会出现一个弹窗广告,一般都是用的setTimeout
了解了定时器的基本知识之后,那么接下来就可以进行功能的实现了。
HTML
<template>
<div class="timer">
<div>{{nowTime}}</div>
</div>
</template>
Javascript
<script>
export default {
name: 'Timer',
data () {
return {
timer: null,
nowTime:"",
hour: 0,
minutes: 0,
seconds: 0
}
},
created () {
this.timer = setInterval(this.startTimer, 1000);
},
destroyed () {
clearInterval(this.timer);
},
methods: {
startTimer () {
//建议开启定时器前,先清除定时器,避免定时器累加,出现不可预期的bug
if(this.timer) {
clearInterval(this.timer);
}
this.seconds += 1;
if (this.seconds >= 60) {
this.seconds = 0;
this.minutes= this.minutes+ 1;
}
if (this.minutes>= 60) {
this.minutes= 0;
this.hour = this.hour + 1;
}
this.nowTime = this.toZero(this.hour): this.toZero(this.minutes):this.toZero(this.seconds)
},
toZero(timeNumber) {
return timeNumber<10?"0"+timeNumber:timeNumber
},
}
}
</script>
这样,一个简单的计时器组件就实现好了,其实还有其他的实现思路,如果以后开发碰到了类似的需求,可以借鉴,希望对你们有所帮助。
到此,相信大家对“vue怎么实现简易计时器组件”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。