AutoCAD 3DMAX C语言 Pro/E UG JAVA编程 PHP编程 Maya动画 Matlab应用 Android
Photoshop Word Excel flash VB编程 VC编程 Coreldraw SolidWorks A Designer Unity3D
 首页 > JavaScript

vue2.0实现倒计时的插件(时间戳 刷新 跳转 都不影响)

51自学网 http://www.wanshiok.com
vue,倒计时,vue2.0,倒计时

我发现好多倒计时的插件,刷新都会变成从头再来,于是自己用vue2.0写了一个,测试通过,直接上代码

如下是组件代码:

<template>  <span :endTime="endTime" :callback="callback" :endText="endText">    <slot>      {{content}}    </slot>  </span></template><script>  export default {    data(){      return {      content: '',      }    },    props:{      endTime:{        type: String,        default :''      },      endText:{        type : String,        default:'已结束'      },      callback : {        type : Function,        default :''      }    },    mounted () {     this.countdowm(this.endTime)    },    methods: {      countdowm(timestamp){      let self = this;      let timer = setInterval(function(){        let nowTime = new Date();        let endTime = new Date(timestamp * 1000);        let t = endTime.getTime() - nowTime.getTime();        if(t>0){          let day = Math.floor(t/86400000);          let hour=Math.floor((t/3600000)%24);          let min=Math.floor((t/60000)%60);          let sec=Math.floor((t/1000)%60);          hour = hour < 10 ? "0" + hour : hour;          min = min < 10 ? "0" + min : min;          sec = sec < 10 ? "0" + sec : sec;          let format = '';          if(day > 0){            format = `${day}天${hour}小时${min}分${sec}秒`;          }           if(day <= 0 && hour > 0 ){            format = `${hour}小时${min}分${sec}秒`;           }          if(day <= 0 && hour <= 0){            format =`${min}分${sec}秒`;          }          self.content = format;          }else{           clearInterval(timer);           self.content = self.endText;           self._callback();          }         },1000);        },        _callback(){        if(this.callback && this.callback instanceof Function){           this.callback(...this);         }      }    }  }</script>

下面是调用代码:

<count-down endTime="1490761620" :callback="callback" endText="已经结束了"></count-down>

ednTime 是时间结束之后的时间戳  callback是结束之后的回调  endText是结束之后的文字显示!

以上所述是小编给大家介绍的vue2.0实现倒计时的插件(时间戳 刷新 跳转 都不影响),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对wanshiok.com网站的支持!


vue,倒计时,vue2.0,倒计时  
上一篇:JavaScript实现父子dom同时绑定两个点击事件,一个用捕获,一个用冒泡时执行顺序的方法  下一篇:JavaScript mixin实现多继承的方法详解