• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >vue > vue2.0实现倒计时的插件(时间戳 刷新 跳转 都不影响)

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

作者:实现丰盛 字体:[增加 减小] 来源:互联网 时间:2017-05-30

本文主要包含vue2.0,vue2.0中文文档,vue2.0教程,vue2.0官网,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>
</div>

下面是调用代码:

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

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

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

</div>

您可能想查找下面的文章:

  • 详解Vue 非父子组件通信方法(非Vuex)
  • vue2.0 与 bootstrap datetimepicker的结合使用实例
  • vue之nextTick全面解析
  • vue学习笔记之vue1.0和vue2.0的区别介绍
  • vue2.0中goods选购栏滚动算法的实现代码
  • 一个可复用的vue分页组件
  • vue2.0结合Element实现select动态控制input禁用实例
  • 详解Vue中状态管理Vuex
  • 详解Vue用axios发送post请求自动set cookie
  • VUE 更好的 ajax 上传处理 axios.js实现代码

相关文章

  • 2017-05-30详解vue2路由vue-router配置(懒加载)
  • 2017-05-30vue.js入门教程之基础语法小结
  • 2017-05-30require.js 加载 vue组件 r.js 合并压缩的实例
  • 2017-05-30Vue.JS入门教程之自定义指令
  • 2017-05-30Vue.js实现一个自定义分页组件vue-paginaiton
  • 2017-05-30Vue 2.0中生命周期与钩子函数的一些理解
  • 2017-05-30Vue组件BootPage实现简单的分页功能
  • 2017-05-30Vue概念及常见命令介绍(1)
  • 2017-05-30Vue.js如何优雅的进行form validation
  • 2017-05-30Vue监听数组变化源码解析

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 详解VUE的状态控制与延时加载刷新
    • Vuejs第八篇之Vuejs组件的定义实例解析
    • Vue.js学习笔记之 helloworld
    • Vue 搭建脚手架
    • Vue2递归组件实现树形菜单
    • vue-cli的webpack模板项目配置文件分析
    • Vue.js中用v-bind绑定class的注意事项
    • Vue自定义指令拖拽功能示例
    • 基于vue2.0+vuex+localStorage开发的本地记事本示例
    • 谈谈Vue.js——vue-resource全攻略

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有