countUp.js实现数字滚动效果


Posted in Javascript onOctober 18, 2019

本文实例为大家分享了countUp.js数字滚动效果展示的具体代码,供大家参考,具体内容如下

1. 概述

1.1 说明

在项目过程中,有时候需要动态的去展示一些数据的加载状态,如一个数字为10000,需要5秒时间滚动加载完成。此时使用countup.js就能够很方便的处理此类功能问题。

1.2 countup.js

countup.js是一个无依赖性、轻量级的javascript类,可用于快速创建动画,以更有趣的方式显示数字/数据。详见countup.js

1.3 countup.js使用

npm install countup  进行安装依赖

import CountUp from "countup"  在页面中引入

new CountUp(target, startVal, endVal, decimals, duration, options)

参数:

  • target: 目标元素的id  *必填
  • startVal:开始的值(从哪个值开始)  *必填
  • endVal:结束的值(滚动到哪个值结束)  *必填
  • decimals:小数位数,默认值为0  *可选
  • duration:动画持续时间,单位为秒,默认值为2  *可选
  • options:选项的可选对象  *可选

                     useEasing:true  --是否使用缓动动画,默认为缓动,可设置为false让其匀速

                     useGrouping:true --对数字进行分组,如12345,按三位一组变为类似12,345这样的

                     separator: ','  --分组时使用的分隔符默认是逗号

                      decimal: '.'  --小数点

                      prefix: ''  --添加前缀如12345,变为¥12345

                      suffix: ''  --添加后缀如12345 通过添加后缀变为12345$,12345元之类的

方法:

暂停/恢复      pauseResume
重置动画       reset
更新值           update(newVal)

2. 代码

2.1 源代码

var CountUp = function(target, startVal, endVal, decimals, duration, options) {
 var self = this;
 self.version = function() {
 return "1.9.2"
 };
 self.options = {
 useEasing: true,
 useGrouping: true,
 separator: ",",
 decimal: ".",
 easingFn: easeOutExpo,
 formattingFn: formatNumber,
 prefix: "",
 suffix: "",
 numerals: []
 };
 if (options && typeof options === "object") {
 for (var key in self.options) {
  if (options.hasOwnProperty(key) && options[key] !== null) {
  self.options[key] = options[key]
  }
 }
 }
 if (self.options.separator === "") {
 self.options.useGrouping = false
 } else {
 self.options.separator = "" + self.options.separator
 }
 var lastTime = 0;
 var vendors = ["webkit", "moz", "ms", "o"];
 for (var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) {
 window.requestAnimationFrame = window[vendors[x] + "RequestAnimationFrame"];
 window.cancelAnimationFrame = window[vendors[x] + "CancelAnimationFrame"] || window[vendors[x] + "CancelRequestAnimationFrame"]
 }
 if (!window.requestAnimationFrame) {
 window.requestAnimationFrame = function(callback, element) {
  var currTime = new Date().getTime();
  var timeToCall = Math.max(0, 16 - (currTime - lastTime));
  var id = window.setTimeout(function() {
  callback(currTime + timeToCall)
  },
  timeToCall);
  lastTime = currTime + timeToCall;
  return id
 }
 }
 if (!window.cancelAnimationFrame) {
 window.cancelAnimationFrame = function(id) {
  clearTimeout(id)
 }
 }
 function formatNumber(num) {
 num = num.toFixed(self.decimals);
 num += "";
 var x, x1, x2, x3, i, l;
 x = num.split(".");
 x1 = x[0];
 x2 = x.length > 1 ? self.options.decimal + x[1] : "";
 if (self.options.useGrouping) {
  x3 = "";
  for (i = 0, l = x1.length; i < l; ++i) {
  if (i !== 0 && ((i % 3) === 0)) {
   x3 = self.options.separator + x3
  }
  x3 = x1[l - i - 1] + x3
  }
  x1 = x3
 }
 if (self.options.numerals.length) {
  x1 = x1.replace(/[0-9]/g,
  function(w) {
  return self.options.numerals[ + w]
  });
  x2 = x2.replace(/[0-9]/g,
  function(w) {
  return self.options.numerals[ + w]
  })
 }
 return self.options.prefix + x1 + x2 + self.options.suffix
 }
 function easeOutExpo(t, b, c, d) {
 return c * ( - Math.pow(2, -10 * t / d) + 1) * 1024 / 1023 + b
 }
 function ensureNumber(n) {
 return (typeof n === "number" && !isNaN(n))
 }
 self.initialize = function() {
 if (self.initialized) {
  return true
 }
 self.error = "";
 self.d = (typeof target === "string") ? document.getElementById(target) : target;
 if (!self.d) {
  self.error = "[CountUp] target is null or undefined";
  return false
 }
 self.startVal = Number(startVal);
 self.endVal = Number(endVal);
 if (ensureNumber(self.startVal) && ensureNumber(self.endVal)) {
  self.decimals = Math.max(0, decimals || 0);
  self.dec = Math.pow(10, self.decimals);
  self.duration = Number(duration) * 1000 || 2000;
  self.countDown = (self.startVal > self.endVal);
  self.frameVal = self.startVal;
  self.initialized = true;
  return true
 } else {
  self.error = "[CountUp] startVal (" + startVal + ") or endVal (" + endVal + ") is not a number";
  return false
 }
 };
 self.printValue = function(value) {
 var result = self.options.formattingFn(value);
 if (self.d.tagName === "INPUT") {
  this.d.value = result
 } else {
  if (self.d.tagName === "text" || self.d.tagName === "tspan") {
  this.d.textContent = result
  } else {
  this.d.innerHTML = result
  }
 }
 };
 self.count = function(timestamp) {
 if (!self.startTime) {
  self.startTime = timestamp
 }
 self.timestamp = timestamp;
 var progress = timestamp - self.startTime;
 self.remaining = self.duration - progress;
 if (self.options.useEasing) {
  if (self.countDown) {
  self.frameVal = self.startVal - self.options.easingFn(progress, 0, self.startVal - self.endVal, self.duration)
  } else {
  self.frameVal = self.options.easingFn(progress, self.startVal, self.endVal - self.startVal, self.duration)
  }
 } else {
  if (self.countDown) {
  self.frameVal = self.startVal - ((self.startVal - self.endVal) * (progress / self.duration))
  } else {
  self.frameVal = self.startVal + (self.endVal - self.startVal) * (progress / self.duration)
  }
 }
 if (self.countDown) {
  self.frameVal = (self.frameVal < self.endVal) ? self.endVal: self.frameVal
 } else {
  self.frameVal = (self.frameVal > self.endVal) ? self.endVal: self.frameVal
 }
 self.frameVal = Math.round(self.frameVal * self.dec) / self.dec;
 self.printValue(self.frameVal);
 if (progress < self.duration) {
  self.rAF = requestAnimationFrame(self.count)
 } else {
  if (self.callback) {
  self.callback()
  }
 }
 };
 self.start = function(callback) {
 if (!self.initialize()) {
  return
 }
 self.callback = callback;
 self.rAF = requestAnimationFrame(self.count)
 };
 self.pauseResume = function() {
 if (!self.paused) {
  self.paused = true;
  cancelAnimationFrame(self.rAF)
 } else {
  self.paused = false;
  delete self.startTime;
  self.duration = self.remaining;
  self.startVal = self.frameVal;
  requestAnimationFrame(self.count)
 }
 };
 self.reset = function() {
 self.paused = false;
 delete self.startTime;
 self.initialized = false;
 if (self.initialize()) {
  cancelAnimationFrame(self.rAF);
  self.printValue(self.startVal)
 }
 };
 self.update = function(newEndVal) {
 if (!self.initialize()) {
  return
 }
 newEndVal = Number(newEndVal);
 if (!ensureNumber(newEndVal)) {
  self.error = "[CountUp] update() - new endVal is not a number: " + newEndVal;
  return
 }
 self.error = "";
 if (newEndVal === self.frameVal) {
  return
 }
 cancelAnimationFrame(self.rAF);
 self.paused = false;
 delete self.startTime;
 self.startVal = self.frameVal;
 self.endVal = newEndVal;
 self.countDown = (self.startVal > self.endVal);
 self.rAF = requestAnimationFrame(self.count)
 };
 if (self.initialize()) {
 self.printValue(self.startVal)
 }
};

2.1 代码示例

<!-- 数字滚动 -->
<template>
 <div id="numScroll" style="width: 200px;height: 200px;font-size: 30px;font-weight: bold;"></div>
</template>

<script>
 import CountUp from "countup"
 export default {
 name: "numberScroll.vue",
 mounted() {
 this.numberScroll()
 },
 methods: {
 numberScroll() {
 let count = new CountUp("numScroll", 0, 56565, 0, 5, {duration: 5, useEasing: false})
 if (!count.error) {
  count.start()
 } else {
  console.log(count.error)
 }
 }
 }
 }
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript中使用ActiveXObject操作本地文件夹的方法
Mar 28 Javascript
js中window.open打开一个新的页面
Aug 10 Javascript
在css加载完毕后自动判断页面是否加入css或js文件
Sep 10 Javascript
JS烟花背景效果实现方法
Mar 03 Javascript
js实现透明度渐变效果的方法
Apr 10 Javascript
学习Javascript面向对象编程之封装
Feb 23 Javascript
基于javascript制作经典传统的拼图游戏
Mar 22 Javascript
javascript实现标签切换代码示例
May 22 Javascript
Jquery鼠标放上去显示全名的实现方法
Feb 06 Javascript
vue-cli监听组件加载完成的方法
Sep 07 Javascript
在vue中使用Base64转码的案例
Aug 07 Javascript
vue实现可拖拽的dialog弹框
May 13 Vue.js
Vue-cli3项目引入Typescript的实现方法
Oct 18 #Javascript
细述Javascript的加法运算符的具体使用
Oct 18 #Javascript
ElementUI之Message功能拓展详解
Oct 18 #Javascript
js实现简易计算器功能
Oct 18 #Javascript
JavaScript实现更换背景图片
Oct 18 #Javascript
jquery轻量级数字动画插件countUp.js使用详解
Oct 17 #jQuery
CountUp.js数字滚动插件使用方法详解
Oct 17 #Javascript
You might like
两个php日期控制类实例
2014/12/09 PHP
浅析Yii2集成富文本编辑器redactor实例教程
2016/04/25 PHP
Yii数据读取与跳转参数传递用法实例分析
2016/07/12 PHP
PHP类的自动加载机制实现方法分析
2019/01/10 PHP
javascript 触发事件列表 比较不错
2009/09/03 Javascript
Javascript中的变量使用说明
2010/05/18 Javascript
javascript使用isNaN()函数判断变量是否为数字
2013/09/21 Javascript
javascript异步处理工作机制详解
2015/04/13 Javascript
简述AngularJS的控制器的使用
2015/06/16 Javascript
javascript实现输出指定行数正方形图案的方法
2015/08/03 Javascript
JS清除字符串中重复值的实现方法
2016/08/03 Javascript
JS字符串按逗号和回车分隔的方法
2017/04/25 Javascript
JavaScript 上传文件(psd,压缩包等),图片,视频的实现方法
2017/06/19 Javascript
Vue.js实例方法之生命周期详解
2017/07/03 Javascript
vue-router 权限控制的示例代码
2017/09/21 Javascript
Angular实现的自定义模糊查询、排序及三角箭头标注功能示例
2017/12/28 Javascript
babel7.x和webpack4.x配置vue项目的方法步骤
2019/05/12 Javascript
利用JS响应式修改vue实现页面的input值
2019/09/02 Javascript
JQuery常用选择器功能与用法实例分析
2019/12/23 jQuery
[42:56]VGJ.S vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
python爬虫入门教程--利用requests构建知乎API(三)
2017/05/25 Python
python和pygame实现简单俄罗斯方块游戏
2021/02/19 Python
将python图片转为二进制文本的实例
2019/01/24 Python
python logging模块书写日志以及日志分割详解
2019/07/22 Python
使用python脚本自动创建pip.ini配置文件代码实例
2019/09/20 Python
python实现替换word中的关键文字(使用通配符)
2020/02/13 Python
pytorch数据预处理错误的解决
2020/02/20 Python
安装pyecharts1.8.0版本后导入pyecharts模块绘图时报错: “所有图表类型将在 v1.9.0 版本开始强制使用 ChartItem 进行数据项配置 ”的解决方法
2020/08/18 Python
利用三角函数在canvas上画虚线的方法
2018/01/11 HTML / CSS
英国邮购活的植物主要供应商:Gardening Direct
2019/01/28 全球购物
汽车制造与装配专业自荐信范文
2014/01/02 职场文书
中式面点餐厅创业计划书
2014/01/29 职场文书
《月亮湾》教学反思
2014/04/14 职场文书
少先大队干部竞选稿
2015/11/20 职场文书
《青山不老》教学反思
2016/02/22 职场文书
Python 第三方库 openpyxl 的安装过程
2022/12/24 Python