vue3-count-to实现数字动态增长效果

vue3-count-to 是一个用于 Vue 3的数字计数动画库,常用于在页面上实现数字的动态增长效果,类似于从某个起始值渐变到目标值的效果。它可以用来显示各种数字、统计数据或展示动画效果。

1 安装 vue3-count-to

首先,你需要安装 vue3-count-to 包:

javascript 复制代码
npm install vue3-count-to

或者使用 yarn:

javascript 复制代码
yarn add vue3-count-to

二 属性

vue3-count-to 提供了一些常用的属性来控制动画效果:

  • start-val: 起始值(默认为 0)。
  • end-val: 目标数字(必选项)。
  • duration: 动画时长(单位:毫秒),控制从起始值到目标值的过渡时间。
  • prefix: 设置数字的前缀。
  • suffix: 设置数字的后缀。
  • decimals: 设置数字的小数位数(默认为 0)。
  • decimal: 设置小数点分隔符。
属性 描述 类型 默认值
startVal 起始值 Number 0
endVal 结束值 Number 2017
duration 持续时间(以毫秒为单位) Number 3000
autoplay 自动播放 Boolean true
decimals 分割小数 Number 0
decimal 设置小数点分隔符 String .
separator 分隔符 String ,
prefix 前缀 String ''
suffix 后缀 String ''

三 案例

javascript 复制代码
 <countTo :startVal='startVal' :endVal='endVal' :decimals="2" decimal="," separator="." :duration='3000'></countTo>
javascript 复制代码
let startVal = ref(0)
let endVal = ref(0)
let totalRecharge = ref(null)
let interval = ref(null)


const getTotalRecharge = (() => {
  api.getTotalRecharge().then((data) => {
    totalRecharge.value = data.resource.totalRecharge
  })
})
// 通过watch,把起始值设置为请求后端接口后旧的数据,把结束值设置为新的数据
watch(totalRecharge, (newValue, oldValue) => {
  startVal.value = oldValue
  endVal.value = newValue
})

onMounted(() => {
  getTotalRecharge()
  clearInterval(interval.value)
  interval.value = setInterval(() => {
    getTotalRecharge()
  }, 15000)
})

onBeforeUnmount(() => {
  clearInterval(interval.value)
})
相关推荐
工程师老罗9 小时前
lvgl有哪些布局?
前端·javascript·html
木子清billy9 小时前
物联网浏览器(IoTBrowser)-js开发人脸识别
开发语言·javascript·物联网
关中老四9 小时前
【原生JS甘特图MZGantt 】如何给父任务设置独立进度条
前端·javascript·甘特图
Irene19919 小时前
ES13 # 私有字段( Private Fields) 语法:在类中定义真正的私有属性
javascript·私有字段
WiChP9 小时前
【V0.1B4】从零开始的2D游戏引擎开发之路
前端·javascript·游戏引擎
意法半导体STM329 小时前
【官方原创】STM32CubeProgrammer与STM32 Bootloader连接全流程实战指南 LAT1631
开发语言·前端·javascript·stm32·单片机·嵌入式硬件
Irene19919 小时前
getter 和 方法的区别(数据属性和访问器属性,Vue 3 中,computed 和 getter 的关系和区别)
javascript·vue.js·computed·getter
gCode Teacher 格码致知9 小时前
Javascript提高:Promise、Fetch、Axios、XHR、jQuery AJAX 完整对比-由Deepseek产生
javascript·ajax·jquery
终端鹿9 小时前
Vue3 核心 API 完结篇:toRaw / markRaw / shallowReactive / shallowRef 等进阶响应式 API 详解
前端·javascript·vue.js
sunxunyong9 小时前
集群增加用户&权限
前端·javascript·vue.js