首页 > web前端 > js教程 > 正文

VUE组件的实例:VUE组件如何实现倒计时?

不言
发布: 2018-08-09 17:29:44
原创
2414 人浏览过

 本篇文章给大家带来的内容是关于VUE组件的实例:VUE组件如何实现倒计时?有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

一、效果图:

 

二、CSS代码

.box{
    width: 300px;
    height: 100px;
    line-height: 100px;
    margin: 100px auto;
    background-color: #eee;
    text-align: center;
    font-size: 30px;
    color: #666;
}.count-number{
    color: red;
    font-size: 30px;
    font-weight: bold;
}
登录后复制

三、HTML代码

<p class="wrap">
    <countdown seconds="15" index="1"></countdown>
    <countdown seconds="30" index="2"></countdown></p>
登录后复制

四、javascript代码

// 倒计时组件
Vue.component(&#39;countdown&#39;, {
    props: [&#39;seconds&#39;, &#39;index&#39;],
    data: () => {
         return {
            timerCount: 0
         }
     },
     mounted() {
         this.timing();
     },
     methods: {
         timing() {
             let startTime = localStorage.getItem(`startTime${this.index}`);
             let nowTime = new Date().getTime();
             if(startTime) {
                  let surplus = this.seconds - parseInt((nowTime-startTime) / 1000, 10);
                  this.timerCount = surplus <= 0 ? 0 : surplus;
             } else {
                  this.timerCount = this.seconds;
                  localStorage.setItem(`startTime${this.index}`, nowTime);
             }

             let timer = setInterval(() => {
                  if(this.timerCount > 0 && this.timerCount <= this.seconds) {
                      this.timerCount--;
                 } else {
                      localStorage.removeItem(`startTime${this.index}`);
                      clearInterval(timer);
                  }
             }, 1000);
         }
    },
    template: `<div class="box">倒计时 <span class="count-number">{{timerCount < 10 ? &#39;0&#39; + timerCount : timerCount}}</span> 秒</div>`
});

// Vue实例
new Vue({
    el: &#39;.wrap&#39;
});
登录后复制

 相关推荐:

JS中的原型机制:实现构造函数与其实例的继承与扩展

Vue子组件与父组件之间的通信(附代码)

以上是VUE组件的实例:VUE组件如何实现倒计时?的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!