vue3封装数字滚动组件的实现示例
更新时间:2024年08月02日 10:14:11 作者:月伤59
本文主要介绍了vue3封装数字滚动组件的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
效果展示:
代码:
<template> <div class="counter-container"> <div v-for="(item, index) in numArr" :key="index" :class="item === ',' || item === '.' ? 'mark-item' : 'num-item'"> <span class="pointer" v-if="item == ',' || item == '.'">{{ item }}</span> <span ref="numberItem" v-else class="num"> {{ flipNum }} </span> </div> </div> </template> <script setup lang="ts"> import { ref, watch, nextTick, onMounted } from "vue"; const props = defineProps({ num: { type: Number, default: 0 }, duration: { type: Number, default: 1 } }); let numArr = ref(["0", "0", ",", "0", "0", "0", ",", "0", "0", "0"]); const flipNum = "0123456789"; // let timer = null; const numberItem = ref<Array<HTMLSpanElement> | null>(null); // 处理传递过来的数字,转化为数组 function numToArr() { const str = props.num.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ","); numArr.value = str.split(""); } function rollNum() { const numItems = numberItem.value; const numberArr = numArr.value.filter(item => item !== "," && item !== "."); numberArr.forEach((item, index) => { const num = parseInt(item); if (numItems) { const numItem = numItems[index]; numItem.style.transform = `translate(-50%, -${num * 10}%)`; } }); } // 监听数字变化,更新数字 const initNumber = () => { numToArr(); nextTick(() => { setTimeout(() => { rollNum(); }, props.duration * 1000); }); }; watch( () => props.num, () => { initNumber(); } ); onMounted(() => { initNumber(); }); </script> <style lang="scss" scoped> .counter-container { display: flex; flex-direction: row; align-items: center; justify-content: center; } .counter-container .num-item { position: relative; box-sizing: border-box; width: 22px; height: 34px; padding: 8px; margin-left: 4px; overflow: hidden; font-size: 20px; font-weight: bold; color: #ffffff; text-align: center; background-image: url("@/assets/images/dataBoard/num_wrap.png"); background-repeat: no-repeat; background-size: 100% 100%; } .counter-container .mark-item { height: 34px; margin-left: 4px; font-size: 24px; font-weight: 800; line-height: 38px; color: #ffffff; text-align: center; } .counter-container .num { position: absolute; top: 6px; left: 50%; letter-spacing: 8px; writing-mode: vertical-lr; transition: all 1s ease-in-out; transform: translate(-50%, 0); text-orientation: upright; } </style>
到此这篇关于vue3封装数字滚动组件的实现示例的文章就介绍到这了,更多相关vue3 数字滚动组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
动态实现element ui的el-table某列数据不同样式的示例
这篇文章主要介绍了动态实现element ui的el-table某列数据不同样式的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2021-01-01
最新评论