vue 数字滚动加载

效果:

 

组件封装:

<template><div><div v-for="(item, index) in total" :key="index" class="real-time-num" :style="{width:`${countWidth}px`,height:`${countHeight}px`,lineHeight:`${countHeight}px`,fontSize:`${countFontsize}px`,border:couuntBoder?'none':'2px solid #47e2ff',boxShadow:couuntBoder?'none': '0px 0px 22px 8px #0158cf inset'}"><div class="real-time-num-item" style="transition: all 1s ease-out; ":style="{ transform: item != ',' && item != '.' ? `translateY(-${item * countHeight}px)` : `translateY(-${10 * countHeight}px)` }"><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">0</div><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">1</div><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">2</div><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">3</div><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">4</div><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">5</div><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">6</div><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">7</div><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">8</div><div :style="{width:`${countWidth}px`,height:`${countHeight}px`}">9</div><div class="symbol" :style="{width:`${countWidth}px`,height:`${countHeight}px`}"><span class="comma" v-if="item==','" :style="{top:`${countTop}px`}">{{ item }}</span><span class="drop" v-if="item=='.'">{{ item }}</span></div></div></div><span class="label">{{ unit }}</span></div>
</template>
<script>
export default {props: {totalCounts: [],countWidth:"",countHeight:"",unit:"",countFontsize:"",countTop:"",couuntBoder:true,},data() {return {total: []}},watch: {totalCounts: function (val) {if (val && val.length) {this.total = Array(val.length).fill(0)setTimeout(() => {this.total = this.totalCountsconsole.log(this.total, 'this.totalCounts2');}, 1000);}}}
};
</script>
<style></style>
<style lang="scss" scoped>
.real-time-num {display: inline-block;margin-left: 3px;text-align: center;overflow: hidden; // 隐藏内容
}.real-time-num>div {font-family: "Yourname";
}.real-time-num-item {transition: all 1s ease-out;
}.label {font-size: 20px;height: 5px;
}.symbol {position: relative;.comma {position: absolute;}
}
</style>

 父组件使用:

html:

<Num :totalCounts="totalCounts"  countWidth="46" countHeight="56" unit="m³" countFontsize="52" countTop="32"/>

js:

import Num from './num.vue'
components: {Num}

最初参考文章:如何实现大屏数字滚动效果_大数据看板 实时消息 滚动展示-CSDN博客

可是我就是滚动不起来,直接就到最终结果的数字了!!!

后来不信邪,必须整出来,我发现改变数字就可以动态渲染会滚动于是:

       this.total = Array(val.length).fill(0)setTimeout(() => {this.total = this.totalCounts}, 1000);

这是就是根据刚传过来的数组,初始化位数为传过来的长度以0填充
使用延时器再赋值成真实的数据就可以滚起来了!!!!

后面就是根据使用在不用的地方【 宽、高、字号、要不要边框】这些样式动态传就可以了~

打铁还需自身硬啊 寄希望于他人不如自救! 周五快乐~~ 

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringMVC异常处理机制

2.1 异常描述 在J2EE项目的开发中&#xff0c;不管是对底层的数据库操作过程&#xff0c;还是业务层的处理过程&#xff0c;还是控制层的处理过程&#xff0c;都不可避免会遇到各种可预知的、不可预知的异常需要处理。每个过程都单独处理异常&#xff0c;系统的代码耦合度高&a…

在Sqlite中通过Replace来实现插入和更新

你可能在批量处理一个事务的时候&#xff0c;想要批量插入一系列的数据&#xff0c;但是这些数据当添加完一次之后&#xff0c;重新添加的时候&#xff0c;你不想要重新添加&#xff0c;只是想将原有的数据进行更新&#xff0c;例如&#xff1a;我想要通过Excel将一系列的图书导…

Peter算法小课堂—简单建模(3)

国王的奖赏系列 国王的奖赏1 题目描述&#xff1a; 你作为战斗英雄得到国王的奖赏&#xff0c;可以在地图上选一块土地。地图里共n*m格土地&#xff0c;第x行第y列的土地格子里标记着d[x][y]的整数价值&#xff0c;可能出现负数。国王让你选择若干列土地&#xff0c;只要是连…

springcloudalibaba01

整合springcloud 和 springcloudalibaba&#xff0c;&#xff0c;&#xff0c; 版本对应关系 <dependencyManagement><dependencies><!--每个springcloud的工具都有一个版本每个springcloud alibaba的工具都有一个版本统一版本--> <!-- 整合…

【lesson15】进程控制之进程等待(2)

文章目录 进程等待阻塞式等待非阻塞式等待非阻塞式等待 vs 阻塞式等待 进程等待 上次我们讲了许多关于进程等待的必要性和重要性还有其函数的使用方法&#xff0c;这次我们主要介绍函数细节方面的问题。 阻塞式等待 代码演示进程阻塞式等待 代码&#xff1a; #include <…

STL中sort的底层实现

文章目录 1、源码分析2、算法优化3、总结 在讲解STL中sort的底层原理之前&#xff0c;先引申出这样几个问题&#xff1f; ①STL中sort的底层是采用哪种或者哪几种排序&#xff1f; ②STL中sort会导致栈溢出吗&#xff1f; ③快速排序的时间复杂度是不稳定的 l o g 2 n log_2n l…

力扣22. 括号生成(java 回溯法)

Problem: 22. 括号生成 文章目录 题目描述思路解题方法复杂度Code 题目描述 思路 我们首先要知道&#xff0c;若想生成正确的括号我们需要让右括号去适配左括号&#xff0c;在此基础上我们利用回溯去解决此题目 1.题目给定n个括号&#xff0c;即当回溯决策路径长度等于 2 n 2n…

vue3 + ts 防抖指令,节流指令,复制指令

vue3 ts 自定义指令 防抖指令&#xff0c;节流指令&#xff0c;复制指令 本文使用了 element-ui , element-plus 官网 源文件 https://admin.spicyboy.cn/#/directives/debounceDirect 新建 copy.ts 文件 &#xff08;复制指令&#xff09; import type { Directive, Di…

深入分析ClassLocader工作机制

文章目录 一、ClassLoader简介1. 概念2. ClassLoader类结构分析 二、ClassLoader的双亲委派机制三、Class文件的加载流程1. 简介2. 加载字节码到内存3. 验证与解析4. 初始化Class对象 四、常见加载类错误分析1. ClassNotFoundException2. NoClassDefFoundError3. UnsatisfiledL…

系统的安全性设计

要设计一个安全的系统&#xff0c;除了要了解一些前面讲到的常用的保护手段和技术措施外&#xff0c;还要对系统中可能出现的安全问题或存在的安全隐患有充分的认识&#xff0c;这样才能对系统的安全作有针对性的设计和强化&#xff0c;即“知己知彼&#xff0c;百战百胜”。 下…

NO-IOT翻频,什么是翻频,电信为什么翻频

1.1 翻频迁移最终的目的就是减少网络的相互干扰&#xff0c;提供使用质量. 1.2 随着与日俱增的网络规模的扩大&#xff0c;网内干扰已成了影响网络的质量标准之一&#xff0c;为了保障电信上网体验&#xff0c;满足用户日益增长的网速需求,更好的服务客户&#xff0c;电信针对…

在VS2010上使用C#调用非托管C++生成的DLL文件(图文讲解)

背景 在项目过程中&#xff0c;有时候你需要调用非C#编写的DLL文件&#xff0c;尤其在使用一些第三方通讯组件的时候&#xff0c;通过C#来开发应用软件时&#xff0c;就需要利用DllImport特性进行方法调用。本篇文章将引导你快速理解这个调用的过程。 步骤 1. 创建一个CSharp…