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>

vue 使用async写数字动态加载效果案例

vue 使用async写数字动态加载效果案例

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
  • asp之家 网络编程 m.aspxhome.com