您好,登錄后才能下訂單哦!
小編給大家分享一下如何使用vue實現計時器功能,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
具體內容如下
首先我們要知道setTimeout和setInterval的區別
setTimeout只在指定時間后執行一次,代碼如下:
<script> //定時器 異步運行 function hello(){ alert("hello"); } //使用方法名字執行方法 var t1 = window.setTimeout(hello,1000); var t2 = window.setTimeout("hello()",3000);//使用字符串執行方法 window.clearTimeout(t1);//去掉定時器 </script>
setInterval以指定時間為周期循環執行,代碼如下:
//實時刷新時間單位為毫秒 setInterval('refreshQuery()',8000); /* 刷新查詢 */ function refreshQuery(){ $("#mainTable").datagrid('reload',null); }
一般情況下setTimeout用于延遲執行某方法或功能,
setInterval則一般用于刷新表單,對于一些表單的實時指定時間刷新同步
HTML代碼
<div class="father"> <ul> <li>{{one}}<span>:</span></li> <li>{{two}}<span>:</span></li> <li>{{three}}</li> </ul> <el-button type="primary" @click="startHandler">開始</el-button> <el-button type="primary" @click="endHandler">暫停</el-button> </div>
JAVASCRIPT代碼
<script> export default { name: 'HelloWorld', data(){ return { flag: null, one : '00', // 時 two : '00', // 分 three : '00', // 秒 abc : 0, // 秒的計數 cde : 0, // 分的計數 efg : 0, // 時的計數 } }, props: { msg: String }, mounted() { }, methods:{ // 開始計時 startHandler(){ this.flag = setInterval(()=>{ if(this.three === 60 || this.three === '60'){ this.three = '00'; this.abc = 0; if(this.two === 60 || this.two === '60'){ this.two = '00'; this.cde = 0; if(this.efg+1 <= 9){ this.efg++; this.one = '0' + this.efg; }else{ this.efg++; this.one = this.efg; } }else{ if(this.cde+1 <= 9){ this.cde++; this.two = '0' + this.cde; }else{ this.cde++; this.two = this.cde; } } }else{ if(this.abc+1 <= 9){ this.abc++; this.three = '0' + this.abc; }else{ this.abc++; this.three=this.abc; } } },100) }, // 暫停計時 endHandler(){ this.flag = clearInterval(this.flag) } } } </script>
效果如下:
看完了這篇文章,相信你對“如何使用vue實現計時器功能”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。