1. 程式人生 > 程式設計 >使用vue實現計時器功能

使用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>

程式碼

<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 &l
t;= 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++; www.cppcns.com 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實現計時器功能

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。