广告
返回顶部
首页 > 资讯 > 前端开发 > html >vue如何设计一个倒计时秒杀的组件
  • 841
分享到

vue如何设计一个倒计时秒杀的组件

2024-04-02 19:04:59 841人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关Vue如何设计一个倒计时秒杀的组件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简介:倒计时秒杀组件在电商网站中层出不穷  不过思路

这篇文章将为大家详细讲解有关Vue如何设计一个倒计时秒杀的组件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

简介:

倒计时秒杀组件在电商网站中层出不穷  不过思路万变不离其踪,我自己根据其他资料设计了一个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>
    <h2 >设计一个秒杀倒计时的组件</h2>
    <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如何设计一个倒计时秒杀的组件”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: vue如何设计一个倒计时秒杀的组件

本文链接: https://www.lsjlt.com/news/75906.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue如何设计一个倒计时秒杀的组件
    这篇文章将为大家详细讲解有关vue如何设计一个倒计时秒杀的组件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简介:倒计时秒杀组件在电商网站中层出不穷  不过思路...
    99+
    2022-10-19
  • vue实现秒杀倒计时组件
    本文实例为大家分享了vue实现秒杀倒计时组件的具体代码,供大家参考,具体内容如下 下面是使用Vue实现秒杀倒计时组件 开发思路 1.请求服务器获取这一刻的服务器时间(统一以服务器时...
    99+
    2022-11-12
  • 利用Android设计一个倒计时组件
    目录1 背景2 对比分析2.1 是否是倒计时2.2 支持多任务2.3 支持时间校准2.4 支持同帧刷新2.5 支持延迟执行2.6 支持CPU休眠3 需求目标4 设计类结构5 具体实现...
    99+
    2022-11-12
  • 如何利用momentJs做一个倒计时组件
    今天就跟大家聊聊有关如何利用momentJs做一个倒计时组件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。vue和moment做的一个倒计时展示样式:<template>...
    99+
    2023-06-22
  • 如何使用nodejs设计一个秒杀系统的方法
    小编给大家分享一下如何使用nodejs设计一个秒杀系统的方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!js的作用是什么1、能够嵌入动态文本于HTML页面。2、对浏览器事件做出响应。3、读写HTML元素。4、在数据被提交...
    99+
    2023-06-14
  • vue如何实现同时设置多个倒计时
    这篇文章主要介绍vue如何实现同时设置多个倒计时,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下html如下:<div class="home"> &nb...
    99+
    2023-06-15
  • Android如何实现一个倒计时自定义控件
    这篇“Android如何实现一个倒计时自定义控件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Android如何实现一个倒计...
    99+
    2023-06-29
  • 如何通过C++编写一个简单的倒计时程序?
    C++ 是一种广泛使用的编程语言,在编写倒计时程序方面非常方便和实用。倒计时程序是一种常见的应用,它能为我们提供非常精确的时间计算和倒计时功能。本文将介绍如何使用 C++ 编写一个简单的倒计时程序。实现倒计时程序的关键就是使用计时器来计算时...
    99+
    2023-11-03
    程序 C++ 倒计时
  • JavaScript网页中如何实现一个计算当年还剩多少时间的倒数计时程序
    这篇文章主要介绍JavaScript网页中如何实现一个计算当年还剩多少时间的倒数计时程序,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!实例如下:function count...
    99+
    2022-10-19
  • 如何使用Vue3设计实现一个Model组件浅析
    目录一、组件设计二、需求分析三、实现流程目录结构组件内容实现 API 形式事件处理其他完善总结一、组件设计 组件就是把图形、非图形的各种逻辑均抽象为一个统一的概念(组件)来实现开发的...
    99+
    2022-11-13
    vue3 model vue3 组件 vue3组件开发
  • 如何设计一个支持在线答题中的实时互动的系统
    随着互联网的发展,在线学习已经成为一种普遍的学习方式。在线答题平台的出现,让学习变得更加灵活和便捷。然而,目前大部分在线答题平台只是提供了简单的答题功能,并没有实现实时互动的功能。为了满足学生们对于更加丰富多样化的学习体验的需求,我们需要设...
    99+
    2023-10-21
    - 在线答题 - 实时互动 - 系统设计
  • 如何设计一个安全的MySQL表结构来实现即时通讯功能?
    如何设计一个安全的MySQL表结构来实现即时通讯功能?随着互联网的快速发展,即时通讯成为了人们生活中不可或缺的一部分。而为了保证即时通讯的安全性,一个合理且安全的MySQL表结构设计也变得至关重要。本文将介绍如何设计一个安全的MySQL表结...
    99+
    2023-10-31
    MySQL 安全性 通讯功能
  • 如何设计一个可靠的MySQL表结构来实现文件压缩功能?
    如何设计一个可靠的MySQL表结构来实现文件压缩功能?引言:在现代的应用程序和系统中,文件压缩是一项常用的功能,它可以显著减小文件的大小,节省存储空间,并提高传输效率。本文将介绍如何使用MySQL数据库来实现文件压缩功能,并提供相应的表结构...
    99+
    2023-10-31
    可靠设计 MySQL表结构 文件压缩功能
  • 如何设计一个可靠的MySQL表结构来实现文件上传功能?
    如何设计一个可靠的MySQL表结构来实现文件上传功能文件上传功能是现代网站应用中很常见的功能之一。为实现文件上传功能,我们需要设计一个可靠的MySQL表结构,用来存储上传的文件相关信息。本文将介绍如何设计这样一个表结构,并提供相应的代码示例...
    99+
    2023-10-31
    文件上传 可靠性 MySQL表结构设计
  • 如何设计一个可靠的MySQL表结构来实现邮件发送功能?
    如何设计一个可靠的MySQL表结构来实现邮件发送功能?邮件发送功能是现代应用程序中常见的一个功能。在设计邮件发送功能时,一个重要的考虑是如何存储邮件相关的信息以及邮件的发送状态。MySQL是一个常用的关系型数据库,下面将介绍如何设计一个可靠...
    99+
    2023-10-31
    设计 邮件发送 MySQL表结构
  • 如何设计一个可靠的MySQL表结构来实现文件下载功能?
    如何设计一个可靠的MySQL表结构来实现文件下载功能?在很多应用中,文件下载功能是非常常见和重要的功能。为了实现文件下载功能,我们需要做好数据库表的设计,使其能够存储和管理文件的相关信息。本文将介绍如何设计一个可靠的MySQL表结构来实现文...
    99+
    2023-10-31
    MySQL表 结构 设计 文件 下载
  • 如何设计一个可靠的MySQL表结构来实现文件存储功能?
    如何设计一个可靠的MySQL表结构来实现文件存储功能?目前,文件存储已经成为许多应用程序中不可或缺的一部分。在设计可靠的MySQL表结构时,我们需要考虑以下几个关键因素:文件存储方式文件存储可以采用两种方式:将文件直接存储在数据库中,或者将...
    99+
    2023-10-31
    可靠性设计 MySQL表结构设计 文件存储功能
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作