使用CSS3 + Vue3 + js-tool-big-box工具,实现炫酷五一倒计时动效

时间过得真是飞速,很快又要到一年一度的五一劳动节啦,今年五天假,做好准备了吗?今天我们用CSS3 + Vue3 + 一个前端工具库 js-tool-big-box来实现一个炫酷的五一倒计时动效吧。

目录

[1 先制作一个CSS3样式](#1 先制作一个CSS3样式)

[2 Vue3功能提前准备](#2 Vue3功能提前准备)

[3 使用js-tool-big-box工具完成倒计时](#3 使用js-tool-big-box工具完成倒计时)

[3.1 安装工具](#3.1 安装工具)

[3.2 页面引入](#3.2 页面引入)

[3.3 补充倒计时代码](#3.3 补充倒计时代码)

[4 最后](#4 最后)


1 先制作一个CSS3样式

页面元素比较简单,外面放一个DIV元素,里面两个P元素即可。第一个P元素我们书写"距离五一劳动节还有"这几个字。第二行的P元素用来存放倒计时显示的内容。

最外部的DIV,我们采用flex布局,这样中间的倒计时样式可以水平并且垂直居中。并且给背景设置一个线性的渐变,采用的是 radial-gradient 属性。中间字体的样式重点看一下 font-family background-image 线性渐变以及webkit-text-fill-color透明的的配合设置。代码如下:

css 复制代码
// Vue3 DOM片段
<template>
  <div class="home">
    <p>距离五一劳动节还有</p>
    <p>{{ timeShow }}</p>
  </div>
</template>

// css3设置
<style lang="scss" scoped>
  .home {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100vh;
    background: radial-gradient(#272727, #b052b0);
    p {
      line-height: 100px;
      letter-spacing: 2px;
      position: relative;
      font-size: 60px;
      font-family: Verdana, Geneva, STCaiyun, sans-serif;
      background-image: -webkit-linear-gradient(#d5cabd 0%, #717597 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      margin: 0;
      // -webkit-filter: drop-shadow(2px 2px 15px #b052b0);
    }
  }
</style>

2 Vue3功能提前准备

与Vue2不同的是,Vue3中,我们用 ref来存放一些data数据依赖,这就需要从vue中引入ref这个函数对象,同时设定一个 timeShow 变量,用来存放我们即将要显示的倒计时内容,倒计时肯定要涉及到setInterval定时函数,初步代码如下:

javascript 复制代码
<script setup>
  import { ref } from "vue";
  let timeShow = ref(null);
  let timerId = null;
  
  const doInterval = () => {
    // 这里初始化显示倒计时
    timeShow.value = '';
    timerId = setInterval(() => {
      // 这里每隔一秒显示新的倒计时时间
      timeShow.value = '';
    }, 990)
  }

  doInterval();
</script>

3 使用js-tool-big-box工具完成倒计时

3.1 安装工具

首先第一步,要使用js-tool-big-box这个工具,就需要下载安装,执行以下命令

npm i js-tool-big-box

3.2 页面引入

安装成功后,package.json中会有新的安装显示

这个时候,我们就要在页面中引入工具,工具对外暴露了 timeBox的对象,我们可以使用这个对象里面的方法进行倒计时计算,代码如下:

javascript 复制代码
import { timeBox } from "js-tool-big-box";

3.3 补充倒计时代码

引入成功后,我们就可以使用 timeBox 里面的 getDistanceNow方法来计算倒计时了,这个方法接收2个入参,第一个是目标时间,我们设定为"2024-05-01 00:00:00",第二个参数是非必填的,但他会有一些默认单位返回,也可以按照自己的需求进行个性化修改,补充代码如下:

javascript 复制代码
<script setup>
  import { ref } from "vue";
  import { timeBox } from "js-tool-big-box";
  let timeShow = ref(null);
  let timerId = null;
  
  const doInterval = () => {
    let timeData = timeBox.getDistanceNow('2024-05-01 00:00:00', {afterUnit:''});
    timeShow.value = timeData.fullDateTime;
    timerId = setInterval(() => {
      timeData = timeBox.getDistanceNow('2024-05-01 00:00:00', {afterUnit:''});
      timeShow.value = timeData.fullDateTime;
    }, 990)
  }

  doInterval();
</script>

展示效果如下图:

4 最后

这就是Vue3 + CSS3 + js-tool-big-box 的结合使用,js-tool-big-box 这个工具很强大,我正在总结使用方法:js-tool-big-box使用方法,他不仅可以对日期时间做转换,还可以获取某一年的属相,某一年的法定节假日,对cookie localstorage做存取,等等,很多大家项目中需要单独书写的公共方法,他都有,不需要大家再逐一去安装学习了,很便捷,很强大。

最后,祝大家过一个美好的五一假期。

相关推荐
JUNAI_Strive_ving10 分钟前
番茄小说逆向爬取
javascript·python
看到请催我学习19 分钟前
如何实现两个标签页之间的通信
javascript·css·typescript·node.js·html5
twins352039 分钟前
解决Vue应用中遇到路由刷新后出现 404 错误
前端·javascript·vue.js
qiyi.sky1 小时前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~1 小时前
分析JS Crash(进程崩溃)
java·前端·javascript
哪 吒1 小时前
华为OD机试 - 几何平均值最大子数(Python/JS/C/C++ 2024 E卷 200分)
javascript·python·华为od
安冬的码畜日常1 小时前
【D3.js in Action 3 精译_027】3.4 让 D3 数据适应屏幕(下)—— D3 分段比例尺的用法
前端·javascript·信息可视化·数据可视化·d3.js·d3比例尺·分段比例尺
杨荧2 小时前
【JAVA开源】基于Vue和SpringBoot的洗衣店订单管理系统
java·开发语言·vue.js·spring boot·spring cloud·开源
Q_w77422 小时前
一个真实可用的登录界面!
javascript·mysql·php·html5·网站登录
昨天;明天。今天。2 小时前
案例-任务清单
前端·javascript·css