我发现好多倒计时的插件,刷新都会变成从头再来,于是自己用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是结束之后的文字显示!

转载

最新文章

  1. Java开发中的23种设计模式详解
  2. iOS 常用的向上,向下取整, 四舍五入函数
  3. javascript基础07
  4. jQuery -&gt; bind / live / delegate 的终结者 - on
  5. 如何用JS获取ASP.net中的textbox的值 js获不到text值
  6. C转义字符
  7. JAVA设计模式--strategy(策略者模式)
  8. Divisibility
  9. 对象、对象数组、JSON、JSON数组的相关操作
  10. Sql server中DateDiff用法【转】
  11. 佛山Uber优步司机奖励政策(1月18日~1月24日)
  12. C++编写ATM(1)
  13. 自写 jQuery 大幅弹窗广告插件(不喜勿拍)
  14. nat123外网SSH访问内网LINUX的N种方法
  15. JS添加类似C# string.Format方法
  16. Map 基础用法
  17. 2017-2018-1 Java演绎法 第三周 作业
  18. 网络安全之在Kali Linux上安装Openvas
  19. windows xp + mysql5.5 + phpmyadmin insert 中文繁體
  20. ionic配置

热门文章

  1. Mess it up!搞乱代码
  2. SQL类型转换和数学函数
  3. python之类中的super函数
  4. LeetCode(1):两数之和
  5. php中静态方法和静态属性的介绍
  6. BZOJ4992 [Usaco2017 Feb]Why Did the Cow Cross the Road 最短路 SPFA
  7. 二分搜索-HihoCoder1128
  8. OSX 10.13 以后实现终端FTP命令(转)
  9. hdu1269 有向图强连通 【Tarjan】(模板)
  10. P1799 数列_NOI导刊2010提高(06)