超简单,几行js代码就实现一个 vue3 的数字滚动效果!

预览效果

1. 创建一个template

js 复制代码
<template>
  <div class="num-warp">
    <template v-for="item in numStr">
      <div v-if="item === ','" class="dot">,</div>
      <div
        v-else
        class="num-box"
        :style="{
          transform: ` translateY(${-sh * Number(item)}px)`,
        }"
      >
        <span v-for="i in 10"> {{ i - 1 }} </span>
      </div>
    </template>
  </div>
</template>

2 实现js逻辑部分

ts 复制代码
<script setup lang="ts">
// 这个没有做成组件,做成组件的话,自己稍微改改
import { computed, onMounted, ref } from "vue";

// 基础数据源,或者外部传入
const num = ref(15481245784544);
// 这个是滚动的高度,也就是一个span元素的默认高度,设置的文字大小不同,这个元素的高度也不同,你可以动态计算,我是直接控制台鼠标点击查看的元素大小,比较省事
const sh = ref(60);

// 转化成千分位
const numStr = computed(() => {
  return num.value.toLocaleString();
});

// 这是个测试代码
onMounted(() => {
  setInterval(() => {
    num.value = Math.floor(Math.random() * 100000000000000);
  }, 2000);
});
</script>

实现样式

css 复制代码
<style scoped>
.dot {
  font-size: 40px;
}
.num-warp {
  display: flex;
  height: 60px;
  overflow-y: hidden;
  line-height: 60px;
}
.num-box {
  display: flex;
  flex-direction: column;
  font-size: 40px;
  margin: 0 1px;
  transition: all 1s;
}
</style>
相关推荐
zzywxc7874 分钟前
详细探讨AI在金融、医疗、教育和制造业四大领域的具体落地案例,并通过代码、流程图、Prompt示例和图表等方式展示这些应用的实际效果。
开发语言·javascript·人工智能·深度学习·金融·prompt·流程图
大明885 分钟前
用 mouseover/mouseout 事件代理模拟 mouseenter/mouseleave
前端·javascript
林太白12 分钟前
Nuxt.js搭建一个官网如何简单
前端·javascript·后端
晴空雨13 分钟前
一个符号让 indexOf 判断更优雅!JavaScript 位运算的隐藏技巧
前端·javascript
前端snow26 分钟前
前端无接口实现Table导出Excel的两种方案(附完整代码)
javascript·vue.js·react.js
古夕1 小时前
my-first-ai-web_问题记录03——NextJS 项目框架基础扫盲
前端·javascript·react.js
曲意已决2 小时前
《深入源码理解webpac构建流程》
前端·javascript
CC__xy2 小时前
04 类型别名type + 检测数据类型(typeof+instanceof) + 空安全+剩余和展开(运算符 ...)简单类型和复杂类型 + 模块化
开发语言·javascript·harmonyos·鸿蒙
小奋斗2 小时前
深入浅出:ES5/ES6+数组扁平化详解
javascript·面试
掘金安东尼2 小时前
解读 hidden=until-found 属性
前端·javascript·面试