vue實現簡易計時器組件
在做項目中難免會碰到需要實時刷新,廣告動畫依次出現等等需求,剛最近基于業(yè)務需求,需要實現一個累加通話時長的計時器,這時候就需要定時器登上我們的代碼舞臺了,其實對于計時器,它的原理就是通過定時器來實現的,那么在寫業(yè)務需求之前,我先說說關于定時器的一些知識。
window對象提供了兩個方法來實現定時器的效果,分別是window.setTimeout()和window.setInterval。
在Javascript中,代碼一般都是同步執(zhí)行的,但定時器卻是異步執(zhí)行的。
window.setTimeout(callback,delay); //callback:回調函數 delay:時間間隔時長 window.setInterval(callback,delay);
定時器分為隔時定時器setInterval和延時定時器setTimeout
那么它們兩到底有什么區(qū)別呢?
- setInterval以指定時間為周期循環(huán)執(zhí)行,一般用于刷新表單、復雜動畫的循環(huán)執(zhí)行,對于一些表單的實時指定時間刷新同步
- setTimeout只在指定時間后執(zhí)行一次,像有些網站剛進去會出現一個彈窗廣告,一般都是用的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>
這樣,一個簡單的計時器組件就實現好了,其實還有其他的實現思路,如果以后開發(fā)碰到了類似的需求,可以借鑒,希望對你們有所幫助。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Vue.js axios響應攔截如何獲取返回狀態(tài)碼
這篇文章主要介紹了Vue.js axios響應攔截如何獲取返回狀態(tài)碼問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01
element plus中el-upload實現上傳多張圖片的示例代碼
最近寫項目的時候需要一次上傳多張圖片,本文主要介紹了element plus中el-upload實現上傳多張圖片的示例代碼,具有一定的參考價值,感興趣的可以了解一下2024-01-01

