本文实例为大家分享了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 ""; 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") "[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) "[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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 好薇2024《兵哥哥》1:124K黄金母盘[WAV+CUE]
- 胡歌.2006-珍惜(EP)【步升大风】【FLAC分轨】
- 洪荣宏.2014-拼乎自己看【华特】【WAV+CUE】
- 伊能静.1999-从脆弱到勇敢1987-1996精选2CD【华纳】【WAV+CUE】
- 刘亮鹭《汽车DJ玩主》[WAV+CUE][1.1G]
- 张杰《最接近天堂的地方》天娱传媒[WAV+CUE][1.1G]
- 群星《2022年度发烧天碟》无损黑胶碟 2CD[WAV+CUE][1.4G]
- 罗文1983-罗文甄妮-射雕英雄传(纯银AMCD)[WAV+CUE]
- 群星《亚洲故事香港纯弦》雨果UPMAGCD2024[低速原抓WAV+CUE]
- 群星《经典咏流传》限量1:1母盘直刻[低速原抓WAV+CUE]
- 庾澄庆1993《老实情歌》福茂唱片[WAV+CUE][1G]
- 许巍《在别处》美卡首版[WAV+CUE][1G]
- 林子祥《单手拍掌》华纳香港版[WAV+CUE][1G]
- 郑秀文.1997-我们的主题曲【华纳】【WAV+CUE】
- 群星.2001-生命因爱动听电影原创音乐AVCD【MEDIA】【WAV+CUE】