countUp.js实现数字滚动效果

本文实例为大家分享了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>

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

(0)

相关推荐

  • countup.js实现数字动态叠加效果

    本文实例为大家分享了countup.js实现数字动态叠加效果的具体代码,供大家参考,具体内容如下 CountUp.js 无依赖的.轻量级的 JavaScript 类,可以用来快速创建以一种更有趣的动画方式显示数值数据.尽管它的名字叫 countUp,但其实可以在两个方向进行变化,这是根据你传递的 startVal 和 endVal 参数判断的. 再加上滚轮事件判断. 可配置的参数: target = 目标元素的 ID: startVal = 开始值: endVal = 结束值: decimals

  • countUp.js实现数字动态变化效果

    本文实例为大家分享了countUp.js实现数字动态变化的具体代码,供大家参考,具体内容如下 countUp.js官网:演示地址 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>数字增长效果</title> </head> <body> <h1 id="num1&q

  • jquery轻量级数字动画插件countUp.js使用详解

    CountUp.js是一个无依赖,轻量级的JavaScript"类",可用于快速创建以更有趣的方式显示数字数据的动画. 该JS插件下载地址 展示效果: 详细代码示例: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>jquery轻量级数字动画插件</title> <!-- 该特效该引入的js插件 --> <

  • CountUp.js实现数字滚动增值效果

    数据改动的时候,countUp.js进行数值滚动增加的动态效果,供大家参考,具体内容如下 这是js文件 // target = id of html element or var of previously selected html element where counting occurs // startVal = the value you want to begin at // endVal = the value you want to arrive at // decimals =

  • CountUp.js数字滚动插件使用方法详解

    CountUp.js 是一个轻量级,无依赖的JavaScript类,通过简单的设置就可以达到数字滚动的效果 演示地址: countUp.js 可配置项: target = 目标元素的 ID: startVal = 开始值: endVal = 结束值: decimals = 小数位数,默认值是0: duration = 动画延迟秒数,默认值是2: //用法: var options = { useEasing: true, useGrouping: true, separator: ',', de

  • countUp.js实现数字滚动效果

    本文实例为大家分享了countUp.js数字滚动效果展示的具体代码,供大家参考,具体内容如下 1. 概述 1.1 说明 在项目过程中,有时候需要动态的去展示一些数据的加载状态,如一个数字为10000,需要5秒时间滚动加载完成.此时使用countup.js就能够很方便的处理此类功能问题. 1.2 countup.js countup.js是一个无依赖性.轻量级的javascript类,可用于快速创建动画,以更有趣的方式显示数字/数据.详见countup.js 1.3 countup.js使用 np

  • js焦点文字滚动效果代码分享

    本文实例讲述了js焦点文字滚动效果.分享给大家供大家参考.具体如下: 效果描述: 今天推荐的这个又是一个原生的js焦点图效果 默认自动切换,也可以手动切换 javascript代码采用函数式对象编程,也就是javascript编程中的Module模式 基本用法很简单,主要特点有三: 1.模块化,可重用 2.封装了变量和function,和全局的命名空间不接触,不污染全局变量 3.只暴露可用public方法,其他私有方法全部隐藏,确保js相互之间不会冲突 运行效果图:---------------

  • JS平滑无缝滚动效果的实现代码

    本文我们实现纯JS方式的滚动广告效果. 先show一下成品: 首先是网页样式: #demo { background: #FFF; overflow:hidden; border: 1px dashed #CCC; width: 1280px; height:200px; } #demo img { border: 3px solid #F2F2F2; } #indemo { float: left; width: 800%; } #demo1 { float: left; } #demo2 {

  • js实现数字滚动特效

    本文实例为大家分享了js实现数字滚动展示的具体代码,供大家参考,具体内容如下 效果图 html代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> #t,#tt{ border: #ccc thin solid; width: 250px; heig

  • JavaScript实现余额数字滚动效果

    目录 1.实现背景 2.实现思路 3.实现过程 1.实现背景 上周在一个完成任务领取红包的活动需求中,需要实现一个用户点击按钮弹出领取红包弹窗后,在关 闭弹窗返回原来的页面时,页面余额数字部分要展示一个每一位数字滚动后的效果. 因为之前没做过这样的效果,一开始也不知道要如何实现,本来想在GitHub上找一下相关的库,看到一个最高star的库,但发现它是依赖jQuery的,而且不可以npm包引入.感觉就很没有必要,本来项目是react框架的,就是要尽量少的操作DOM,为了解决这个滚动就要引入jQu

  • js 上下文字滚动效果

    js实现的文字向上滚动效果,适合文字公告等. test #textHeight{line-height:25px; height:25px; overflow:hidden; width:150px; font-size:12px; border:solid 1px #666;} function ScrollText(content){ this.Delay=10; this.Amount=1; this.Direction="up"; this.Timeout=1000; this

  • 原生js实现公告滚动效果

    本文实例为大家分享了js实现公告滚动展示的具体代码,供大家参考,具体内容如下 1.html结构 <body> <div id="notice" class="notice"> <ul id="noticeList"> <li>我是公告1</li> <li>我是公告2</li> <li>我是公告3</li> <li>我是公告4&l

随机推荐