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>
這樣,一個簡單的計時器組件就實現好瞭,其實還有其他的實現思路,如果以後開發碰到瞭類似的需求,可以借鑒,希望對你們有所幫助。
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。