vue 使用async写数字动态加载效果案例
作者:qianyiyiyi 时间:2024-05-09 09:25:35
父组件
<interval-number :number-content="blockHeight" v-if="blockHeight>0"></interval-number>
import IntervalNumber from './IntervalNumber.vue'
components:{
IntervalNumber,
}
子组件
<template>
<span class="IntervalNumber">
{{ counter }}
</span>
</template>
<script>
export default {
name: 'IntervalNumber',
props: {
numberContent: Number
},
data () {
return {
counter: this.numberContent,
timeTicket: null,
}
},
mounted(){
let time = 1000 //ms 数字滚动总时间
let delayTime = 30 // ms 数字滚动间隔时间
let divisions = time / delayTime
this.asyncPrint(this.counter, divisions, delayTime)
},
methods:{
timeOut(ms) {
return new Promise((resolve) => {
this.timeTicket = setTimeout(resolve, ms)
})
},
async asyncPrint(value, divisions, ms){
for(let i=0; i< divisions; i++){
try {
await this.timeOut(ms);
} catch (err) {
console.log(err)
}
this.counter = Math.round(value / divisions * i);
}
this.counter = this.numberContent
clearTimeout(this.timeTicket)
this.timeTicket = null
}
}
}
</script>
补充知识:vue利用 vue-animate-number插件动态展示数字(从0动态滚动到指定数字)
vue-animate-number插件git地址: https://github.com/wangdahoo/vue-animate-number
1.具体实现步骤如下
如果你想展示一下自己的技术,也可以用代码一行一行的写,如果你像我一样“聪明”的话,咱还是用这个插件,亲测效果不错,简单易懂!哈哈,开个玩笑!说正事!
第一步:安装vue-animate-number插件
$ npm install vue-animate-number
第二步:在main.js中引入
import Vue from 'vue'
import VueAnimateNumber from 'vue-animate-number'
Vue.use(VueAnimateNumber)
第三步:在组件中使用
把所有用到的案例都在下面组件中写出
<template>
<div>
<animate-number
from="1"
to="10"
duration="1000"
easing="easeOutQuad"
:formatter="formatter"
></animate-number>
<!-- 最简单的案例,from是开始值,to是结束值 -->
<animate-number from="1" to="10"></animate-number>
<animate-number ref="myNum" from="0" to="10" mode="manual" :formatter="formatter"></animate-number><br>
<!-- 也可以通过按钮去触发-->
<button type="button" @click="startAnimate()"> animate! </button>
</div>
</template>
<script>
export default {
methods: {
formatter: function (num) {
return num.toFixed(2)
},
startAnimate: function () {
this.$refs.myNum.start()
}
}
}
</script>
2.vue-animate-number的API
以上显示的代码以及步骤git上都有,并且也比较详细,没事大家可以浏览一下,收藏起来,用到的时候多方便!
来源:https://blog.csdn.net/u013466380/article/details/105200450
标签:vue,async,数字,加载
0
投稿
猜你喜欢
Python大数据之使用lxml库解析html网页文件示例
2022-05-10 11:06:53
使用Python实现租车计费系统的两种方法
2022-05-12 14:37:24
selenium在scrapy中的使用代码
2021-11-24 09:34:16
WPF滑块控件(Slider)的自定义样式
2022-01-19 20:05:02
详解在OpenCV中实现的图像标注技术
2023-12-01 11:54:34
Mybatis实现分包定义数据库的原理与过程
2024-01-23 12:33:55
JS获取当前时间的实例代码(昨天、今天、明天)
2024-04-23 09:28:36
SQL Server 2005中的CLR集成
2009-03-10 15:07:00
Python知识点详解之正则表达式语法
2022-02-08 17:01:31
Python实现向好友发送微信消息优化篇
2022-02-18 18:07:08
JS自定义混合Mixin函数示例
2024-04-16 10:29:41
Python Sympy计算梯度、散度和旋度的实例
2023-03-11 05:14:10
python学习必备知识汇总
2022-01-05 10:26:23
termux中matplotlib无法显示中文问题的解决方法
2022-12-16 00:07:16
Python如何安装第三方模块
2023-08-01 12:50:07
Python中json模块load/loads方法实战以及参数详解
2022-01-28 14:14:30
在Golang中使用C语言代码实例
2024-05-25 15:15:46
python基础入门之普通操作与函数(三)
2023-11-01 22:52:17
MySQL更新存放JSON的字段、\\“ 转义成 “的问题描述
2024-01-13 16:30:00
mysql建立自定义函数的问题
2024-01-19 06:26:52