封装的数字滚动组件的实现代码

效果:

学习啦:

Vue 是一个渐进式框架,鼓励通过组件化来构建应用,其组件化优势:

  • 代码复用:不同的视图和功能被封装成独立的组件,便于复用。
  • 易于维护:每个组件职责单一、耦合度低,便于维护和扩展。
  • 清晰的结构:应用的结构变得更清晰,逻辑拆分更加简洁。

CSS 动画与 transform:

CSS transform 属性允许你在不影响文档流的情况下对元素进行位移、缩放、旋转等操作。相比使用 margintop 等属性,transform 性能更好,因其不会触发浏览器的重排和重绘

innerHTML 的使用:

innerHTML 是 JavaScript 中用来获取或设置元素的 HTML 内容的属性。虽然它很方便,但使用时需要注意性能问题,因为它会导致页面重新渲染。

mapjoin 方法:

  • map 是数组的一个高阶方法,用于遍历数组并对每个元素应用一个函数,返回一个新的数组。应用场景:用于生成每个数字项的 HTML 代码。
  • join 方法用于将数组元素连接成一个字符串,并且可以指定分隔符,应用于将所有生成的 HTML 字符串拼接成一个长字符串

实现思路:

  1. 格式化数字:处理负数、小数点和符号。
  2. 数字转数组:拆分数字为字符,便于渲染。
  3. 创建 DOM 元素:为每个字符生成对应的滚动容器。
  4. 初始化渲染和动画:根据数字创建滚动项并启动动画。
  5. 滚动动画优化:使用 transform: translateY() 替代 margin-top,提升性能。
  6. 响应数字变化:实时更新数字和滚动效果。
  7. 样式优化:确保显示效果清晰,滚动平滑。

封装代码:

<template><div class="scroll-number-container" ref="scrollContainer"></div>
</template><script setup>
import { ref, watch, onMounted } from 'vue';const props = defineProps({number: {type: [Number, String],required: true,},duration: {type: Number,default: 500,},
});// 用于引用 DOM 元素
const scrollContainer = ref(null);// 格式化数字,支持格式化负数、小数和千位分隔符
const formatNumber = (num) => {// 数字转字符串并考虑负数if (num < 0) {return `-${Math.abs(num).toString()}`;}return num.toString();
};// 将数字字符串转为数组,支持负号和小数点
const numberToArr = (num) => {const formatted = formatNumber(num);return formatted.split('');
};// 创建每个数字的滚动效果 DOM 元素
const createScrollItem = (digit) => {if (/\d/.test(digit)) {return (`<div class="scrollItem"><div class="scrollItem-content" data-show="${digit}"><span>0</span><span>1</span><span>2</span><span>3</span><span>4</span><span>5</span><span>6</span><span>7</span><span>8</span><span>9</span></div></div>`);} else {// 对于负号、小数点等非数字字符单独处理return `<div class="sign-box"><span>${digit}</span></div>`;}
};// 更新滚动动画
const animateScroll = () => {const height = scrollContainer.value.clientHeight;const scrollItems = scrollContainer.value.querySelectorAll('.scrollItem-content');scrollItems.forEach((item) => {const num = parseInt(item.getAttribute('data-show'));const translateY = height * num;item.style.transition = `transform ${props.duration}ms ease-in-out`;item.style.transform = `translateY(-${translateY}px)`;});
};// 初始化,渲染数字列表
const init = () => {const numArr = numberToArr(props.number);scrollContainer.value.innerHTML = numArr.map(createScrollItem).join('');animateScroll();
};onMounted(() => {init();
});// 监听数字变化
watch(() => props.number, init);
</script><style lang="scss">
.scroll-number-container {display: flex;height: 28px;overflow: hidden;font-size: 20px;font-weight: bold;margin: 10px;
}.scrollItem {display: flex;flex-direction: column;line-height: 28px;width: 25px;text-align: center;
}.scrollItem-content {display: flex;flex-direction: column;transition: transform 0.5s ease-in-out;
}.scrollItem-content span {font-size: 32px;font-family: 'YouSheBiaoTiHei';
}.sign-box {display: flex;align-items: center;justify-content: center;font-size: 32px;font-family: 'YouSheBiaoTiHei';
}
</style>

封装组件应用:

<template><div id="app"><h1>数字滚动效果</h1><ScrollNumber :number="currentNumber" :duration="1000" /><button @click="changeNumber">更改数字</button></div>
</template><script setup>
// 导入子组件
import ScrollNumber from './components/ScrollNumber.vue';import { ref } from 'vue';const currentNumber = ref(1234);  // 初始数字// 事件处理函数,用于更改数字
const changeNumber = () => {currentNumber.value = Math.floor(Math.random() * 10000);  // 随机生成一个数字
};
</script><style>
#app {text-align: center;margin-top: 50px;
}button {margin-top: 20px;padding: 10px 20px;font-size: 16px;cursor: pointer;
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/10385.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Unity跨平台基本原理

目录 前言 ​编辑 Mono Unity和Mono的关系 Unity跨平台必备概念 Mono利用 Mono主要构成部分 基于Mono跨平台的优缺点 IL2CPP Mono和IL2CPP的区别 Mono IL2CPP Mono和IL2CPP的使用建议 安装IL2CPP IL2CPP打包存在的问题 类型裁剪 泛型问题 前言 Unity跨平台的基…

计算机网络(3)

UDP是面向无连接的通信协议&#xff0c;UDP数据包括目的端口号和源端口号信息&#xff0c;由于 不需要连接&#xff0c;所以可以实现广播发送&#xff1b; 传输控制层 UDP协议&#xff08;用户数据报协议&#xff09; UDP通信时不需要接收方确认&#xff0c;属于不可靠的传输&a…

2024年11月8日上海帆软用户大会

2024年11月8日上海帆软用户大会 2024年11月8日&#xff0c;上海成功举办了帆软用户大会&#xff0c;主题为“数字聚力&#xff0c;绽放新机”。大会汇聚了众多行业专家和企业代表&#xff0c;共同探讨数字化转型和商业智能领域的最新趋势和实践。 大会亮点&#xff1a; 专家…

PySimpleGUI和Pymysql

PySimpleGUI 库 PySimpleGUI 是一个用于简化 GUI 编程的 Python 包&#xff0c;它封装了多种底层 GUI 框架&#xff08;如 tkinter、Qt、WxPython 等&#xff09;&#xff0c;提供了简单易用的 API。PySimpleGUI 包含了大量的控件&#xff08;也称为小部件或组件&#xff09;&…

Qt Event事件系统小探1

目录 Qt Event System From qt.doc 如何传递事件 事件类型 事件处理程序 事件过滤器 发送事件 事件的产生和派发 处理我们的事件 来一段好玩的代码 扩展&#xff1a;QWidget如何处理我们的事件&#xff1f; 扩展2&#xff1a;实现一个变色的Label Qt Event System Fr…

文章解读与仿真程序复现思路——电网技术EI\CSCD\北大核心《基于凸多面体仿射变换的用户侧灵活性资源多元聚合方法》

本专栏栏目提供文章与程序复现思路&#xff0c;具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源…

vue3组合式API下封装hooks使用生命周期,在await之后调用hooks会有警告

起因&#xff1a;想封装一个hooks实现echarts图表随屏幕大小resize并且组件销毁时移除监听。结果在组件里面调用这个hooks&#xff0c;有个告警提示 [Vue warn]: onBeforeUnmount is called when there is no active component instance to be associated with. Lifecycle inje…

使用Python实现图像的手绘风格效果

使用Python实现图像的手绘风格效果 一、引言二、代码详细解释与示例三、完整框架流程四、运行五、结论附&#xff1a;完整代码 一、引言 在数字图像处理领域&#xff0c;模拟手绘风格是一项有趣且具有挑战性的任务。手绘风格图像通常具有独特的纹理和深浅变化&#xff0c;给人…

window中借助nginx配置vite+vue项目的反向代理步骤

在官网下载好nginx的安装包后&#xff0c;解压后 CMD打开 start nginx 是启动命令 nginx -s stop 停止服务 nginx -s reload 如果重写了nginx.conf文件&#xff0c;要执行这条命令 正常情况下 成功启动和成功停止服务长这样 错误情况&解决 如果nginx -s stop失败 ngi…

花指令例子

如图所示&#xff1a; 指令EB FF的汇编代码为jmp -1&#xff0c;CPU执行到地址处0x6c80c0的指令EB FF时(jmp -1)&#xff0c;EIP为6c80c2, 执行后&#xff0c;EIP为0x6c80c1。但是反汇编器无法自动识别该指令。

关于我的编程语言——C/C++——第八篇

&#xff08;叠甲&#xff1a;如有侵权请联系&#xff0c;内容都是自己学习的总结&#xff0c;一定不全面&#xff0c;仅当互相交流&#xff08;轻点骂&#xff09;我也只是站在巨人肩膀上的一个小卡拉米&#xff0c;已老实&#xff0c;求放过&#xff09; 什么是C C语言是结…

博客园美化

1、主题介绍 使用的 SimpleMemory 这款主题 github官网 2、设置主题并申请 js 代码权限 3、主题设置 博客侧边栏公告 <script type"text/javascript">window.cnblogsConfig {info: {blogIcon: https://ts1.cn.mm.bing.net/th/id/R-C.85775e482741cb7ab7f…

SpringBoot基础系列学习(二):配置详解

文章目录 一丶依赖二丶配置文件三丶获取配置文件中的信息1.PropertySource("classpath:application2.properties")2. ConfigurationProperties(prefix "baicaizhi1")3. Value4. 使用EnviromentgBean获取5. 使用ResourceBundle获取 一丶依赖 <dependen…

初识Electron 进程通信

概述 Electron chromium nodejs native API&#xff0c;也就是将node环境和浏览器环境整合到了一起&#xff0c;这样就构成了桌面端&#xff08;chromium负责渲染、node负责操作系统API等&#xff09; 流程模型 预加载脚本&#xff1a;运行在浏览器环境下&#xff0c;但是…

建网站怎么建?只需几个步骤

在这个网络飞速发展的时代&#xff0c;越来越多的人都渴望拥有自己的网站。然而&#xff0c;对于大多数新手来说&#xff0c;如何建立自己的网站可能充满了挑战。本文将为您详细介绍建网站的关键步骤&#xff0c;让您能够轻松搭建自己的网站。 选择适合的建站工具 虽然市面上有…

台达控制器与三菱变频器实现EtherCAT转CC-Link IEFB协议通讯方案

一.项目背景&#xff1a; 在某自动化生产车间中&#xff0c;原有系统采用台达的 EtherCAT 控制器来控制多个设备的运动和操作&#xff0c;但车间内的一些关键设备使用的是三菱变频器&#xff0c;且基于 CC-Link IEFB 协议通讯。为了实现整个系统的集中控制和数据统一管理&#…

Js — 防抖及底层实现

防抖&#xff1a;单位时间内&#xff0c;频繁触发事件&#xff0c;只执行最后一次 防抖实现方式&#xff1a; lodash提供的防抖函数_.debounce(func,[wait0],[option]) 延迟wait毫秒后调用func方法 定时器setTimeout 目标&#xff1a;鼠标在盒子上移动&#xff0c;鼠标停止50…

负载均衡式在线oj项目开发文档2(个人项目)

judge模块的框架 完成了网页渲染的功能之后&#xff0c;就需要判断用户提交的代码是否是正确的&#xff0c;当用户点击提交之后&#xff0c;就会交给路由模块的/judge模块&#xff0c;然后这个路由模块就需要去调用jude模块了&#xff0c;也就是需要一个新的jude模块&#xff…

setContentView调用流程(二) -将布局添加到mContentParent

Android setContentView执行流程(一)-生成DecorView Android setContentView执行流程(二)-将布局添加到mContentParent 上篇博客我们介绍了setContentView的第一步即生成DecorView以及获取到mContentParent的流程&#xff0c;同时还提到继承自Activity和AppCompatActivity生成…

【C#设计模式(2)——工厂模式】

前言 工厂模式&#xff1a;使用工厂创建对象。工厂模式的主要目的是分离对象的创建与调用&#xff0c;通过使用工厂统一管理对象的创建。工厂模式可以隐藏对象的创建细节&#xff0c;使客户终端代码只关注使用对象而不需要关注对象的创建过程。 运行结果 代码 #region 食品 /…