vue设计一个倒计时秒杀的组件详解


Posted in Javascript onApril 06, 2019

简介:

倒计时秒杀组件在电商网站中层出不穷  不过思路万变不离其踪,我自己根据其他资料设计了一个vue版的

核心思路:

  1. 1、时间不能是本地客户端的时间  必须是服务器的时间这里用一个settimeout代替 以为时间必须统一 
  2. 2、开始时间,结束时间通过父组件传入,当服务器时间在这个开始时间和结束时间的范围内  参加活动按钮可以点击,并且参加过活动以后不能再参加,
  3. 3、在组件创建的时候 同步得到现在时间服务时间差,并且在这里边设置定时器,每秒都做判断看秒杀是否开始和结束,
  4. 4、在更新时间的函数中是否开始和结束,
  5. 5、在computed钩子中监听disable 确定按钮是否可点击
  6. 6、参加过活动在updated中停止定时器的计时,页面销毁的时候也停止计时

下边是代码
子组件

<template>
  <div>
    <button @click="handleClick" :disabled="disabled">
      {{btnText}}
    </button>
    <span>{{tip}}</span>
  </div>
</template>

<script>

  import moment from 'moment'

  export default {
    name: "Spike",
    props: {
      startTime: {
        required: true,
        validator: (val) => {
          return moment.isMoment(val)
        }
      },
      endTime: {
        required: true,
        validator: (val) => {
          return moment.isMoment(val)
        }
      }
    },
    data() {
      return {
        start: false,
        end: false,
        done: false,
        tip: '',
        timeGap: 0,
        btnText:""
      }
    },
      computed: {
      disabled() {
        //当三个异号的时候disable返回真,不可点击,
        // 初始化通过this.updateState确定disable的状态
        return !(this.start && !this.end && !this.done);
      }
    },
    async created() {
      const serverTime=await this.getServerTime();
      this.timeGap=Date.now()-serverTime;//当前时间和服务器时间差
      this.updateState();
      this.timeInterval=setInterval(()=>{
        this.updateState()
      },1000)
    },
    updated(){
      if(this.end||this.done){
        clearInterval(this.timeInterval)
      }
    },
    methods: {
      handleClick() {
        alert("提交成功");
        this.done=true;
        this.btnText="已参加过活动"
      },
      getServerTime() {
        //模拟服务器时间
        return new Promise((resolve, reject) => {
          setTimeout(() => {
            //当前时间慢10秒就是服务器时间
            resolve(new Date(Date.now() -10 * 1000).getTime())//跟本地时间差
          }, 0)
        })
      },
      updateState() {
        const now = moment(new Date(Date.now() - this.timeGap));//当前服务器时间
        const diffStart=this.startTime.diff(now);//开始时间和服务器时间之差
        const diffEnd=this.endTime.diff(now);//结束时间和服务器时间之差
        if(diffStart<0){
          this.start=true;
          this.tip="秒杀已开始";
          this.btnText="参加"
        }else{
          this.tip=`距离秒杀开始还剩${Math.ceil(diffStart/1000)}秒`;
          this.btnText="活动未开始";
        }
        if(diffEnd<=0){
          this.end=true;
          if( !this.btnText==="已参加过活动"||this.btnText==="参加"){
            this.tip="秒杀已结束";
            this.btnText="活动已结束";
          }
        }
      }
    },
    beforeDestroy() {
      clearInterval(this.timeInterval)
    }
  }
</script>

<style scoped>
  button[disabled]{
    cursor: not-allowed;
  }
</style>

父组件

<template>
  <div>
    <h1 style="color: red">设计一个秒杀倒计时的组件</h1>
    <Spike :startTime="startTime" :endTime="endTime"></Spike>
  </div>
</template>

<script>
  import Spike from './Spike'
  import moment from 'moment'
  export default {
    name: "index",
    components:{
      Spike
    },
    data(){
      return{
        endTime:moment(new Date(Date.now()+10*1000)),
        startTime:moment(new Date(Date.now()))
      }
    }
  }
</script>

<style scoped>

</style>

以上所述是小编给大家介绍的vue设计一个倒计时秒杀的组件详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
基于Jquery的仿照flash放大图片效果代码
Mar 16 Javascript
JavaScript中setAttribute用法介绍
Jul 20 Javascript
使用jQuery获得内容以及内容的属性
Feb 26 Javascript
微信jssdk在iframe页面失效问题的解决措施
Mar 03 Javascript
jQuery实现订单提交页发送短信功能前端处理方法
Jul 04 Javascript
详解AngularJS中$filter过滤器使用(自定义过滤器)
Feb 04 Javascript
深入理解javascript的getTime()方法
Feb 16 Javascript
JS正则获取HTML元素的方法
Mar 31 Javascript
微信小程序实现滑动删除效果
May 19 Javascript
AngularJS基于factory创建自定义服务的方法详解
May 25 Javascript
layer子层给父层页面元素赋值,以达到向父层页面传值的效果实例
Sep 22 Javascript
JS中作用域以及变量范围分析
Jul 18 Javascript
js字符串处理之绝妙的代码
Apr 05 #Javascript
微信小程序自定义导航栏实例代码
Apr 05 #Javascript
Node.js事件的正确使用方法
Apr 05 #Javascript
利用Node.js如何实现文件循环覆写
Apr 05 #Javascript
详解JavaScript栈内存与堆内存
Apr 04 #Javascript
jQuery中实现text()的方法
Apr 04 #jQuery
基于 jQuery 实现键盘事件监听控件
Apr 04 #jQuery
You might like
收音机玩机评测 406 篇视频合集
2020/03/11 无线电
使用PHP导出Redis数据到另一个Redis中的代码
2014/03/12 PHP
PHP中构造函数和析构函数解析
2014/10/10 PHP
PHP中把数据库查询结果输出为json格式简单实例
2015/04/09 PHP
PHP登录验证码的实现与使用方法
2016/07/07 PHP
PHP基于双向链表与排序操作实现的会员排名功能示例
2017/12/26 PHP
YII框架行为behaviors用法示例
2019/04/26 PHP
仿jQuery的siblings效果的js代码
2011/08/09 Javascript
Jquery uploadify图片上传插件无法上传的解决方法
2013/12/16 Javascript
jquery提交form表单简单示例分享
2014/03/03 Javascript
js构造函数、索引数组和属性的实现方式和使用
2014/11/16 Javascript
实例剖析AngularJS框架中数据的双向绑定运用
2016/03/04 Javascript
jQuery+ajax实现滚动到页面底部自动加载图文列表效果(类似图片懒加载)
2016/06/07 Javascript
bootstrap导航条实现代码
2016/12/28 Javascript
JavaScript中日常收集常见的10种错误(推荐)
2017/01/08 Javascript
JS简单判断字符在另一个字符串中出现次数的2种常用方法
2017/04/20 Javascript
前端开发不得不知的10个最佳ES6特性
2017/08/30 Javascript
vue2.0$nextTick监听数据渲染完成之后的回调函数方法
2018/09/11 Javascript
详解微信小程序获取当前时间及日期的方法
2019/04/28 Javascript
JS手写一个自定义Promise操作示例
2020/03/16 Javascript
Element图表初始大小及窗口自适应实现
2020/07/10 Javascript
详解如何在Javascript中使用Object.freeze()
2020/10/18 Javascript
[01:16:28]DOTA2-DPC中国联赛 正赛 iG vs Magma BO3 第二场 2月23日
2021/03/11 DOTA
python实现的DES加密算法和3DES加密算法实例
2015/06/03 Python
Python装饰器知识点补充
2018/05/28 Python
75条笑死人的知乎神回复,用60行代码就爬完了
2019/05/06 Python
最新销售员个人自荐信
2013/09/21 职场文书
国贸类专业毕业生的求职信分享
2013/12/08 职场文书
关于责任的演讲稿
2014/05/20 职场文书
学校法制宣传月活动总结
2014/07/03 职场文书
小学优秀教师先进事迹材料
2014/12/16 职场文书
2014年幼儿园园长工作总结
2014/12/17 职场文书
2015年食品安全工作总结
2015/05/15 职场文书
2015年食品安全宣传周活动总结
2015/07/09 职场文书
2016年先进班集体事迹材料
2016/02/26 职场文书
vue基于Teleport实现Modal组件
2021/05/31 Vue.js