欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

使用countUp.js怎么實現(xiàn)一個數(shù)字滾動效果-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)使用countUp.js怎么實現(xiàn)一個數(shù)字滾動效果,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

創(chuàng)新互聯(lián)網(wǎng)站建設(shè)服務(wù)商,為中小企業(yè)提供做網(wǎng)站、成都網(wǎng)站建設(shè)服務(wù),網(wǎng)站設(shè)計,成都網(wǎng)站托管等一站式綜合服務(wù)型公司,專業(yè)打造企業(yè)形象網(wǎng)站,讓您在眾多競爭對手中脫穎而出創(chuàng)新互聯(lián)。

1.1 說明

在項目過程中,有時候需要動態(tài)的去展示一些數(shù)據(jù)的加載狀態(tài),如一個數(shù)字為10000,需要5秒時間滾動加載完成。此時使用countup.js就能夠很方便的處理此類功能問題。

1.2 countup.js

countup.js是一個無依賴性、輕量級的javascript類,可用于快速創(chuàng)建動畫,以更有趣的方式顯示數(shù)字/數(shù)據(jù)。詳見countup.js

1.3 countup.js使用

npm install countup  進(jìn)行安裝依賴

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

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

參數(shù):

  • target: 目標(biāo)元素的id  *必填

  • startVal:開始的值(從哪個值開始)  *必填

  • endVal:結(jié)束的值(滾動到哪個值結(jié)束)  *必填

  • decimals:小數(shù)位數(shù),默認(rèn)值為0  *可選

  • duration:動畫持續(xù)時間,單位為秒,默認(rèn)值為2  *可選

  • options:選項的可選對象  *可選

                     useEasing:true  --是否使用緩動動畫,默認(rèn)為緩動,可設(shè)置為false讓其勻速

                     useGrouping:true --對數(shù)字進(jìn)行分組,如12345,按三位一組變?yōu)轭愃?2,345這樣的

                     separator: ','  --分組時使用的分隔符默認(rèn)是逗號

                      decimal: '.'  --小數(shù)點

                      prefix: ''  --添加前綴如12345,變?yōu)椋?2345

                      suffix: ''  --添加后綴如12345 通過添加后綴變?yōu)?2345$,12345元之類的

方法:

暫停/恢復(fù)      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 代碼示例

<!-- 數(shù)字滾動 -->
<template>
 <div id="numScroll" ></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>

關(guān)于使用countUp.js怎么實現(xiàn)一個數(shù)字滾動效果就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

新聞名稱:使用countUp.js怎么實現(xiàn)一個數(shù)字滾動效果-創(chuàng)新互聯(lián)
網(wǎng)站路徑:http://aaarwkj.com/article22/isdjc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、動態(tài)網(wǎng)站網(wǎng)站設(shè)計、網(wǎng)站改版、網(wǎng)頁設(shè)計公司面包屑導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
亚洲国产欧美日韩国产| 亚欧乱色熟女一区二区三区| 国产一区二区精品日韩| 老熟妇仑乱换频一区二区| 99久久精品国产熟女拳交| 国产精品中文字幕第一页| 超碰欧美性欧美最猛性| 日韩国产亚洲欧美国产| 国产精品蜜臀av在线一区| 青青草原天堂在线免费观看| 国产成人自拍激情视频| 久久精品国产亚洲av波多| 国产成十人十综合十亚洲| 中文字幕在线日韩精品| 永久黄区观看在线网址| 国内熟妇人妻色在线三级| 久章草在线免费视频播放| 国产一区二区三区自拍| 亚洲av色男人天堂网| 欧美视频综合一级91| 未满18周岁禁止观看视频| 国产麻豆三级在线观看| 国产一区二区乱码在线| 亚洲欧美精品福利在线| 十八禁在线观看网址免费| 又黄又湿又刺激中文字幕| 亚洲一区二区精品91眼镜| 日韩欧美国产麻豆一区精品| 日韩精品人妻一区二区三区蜜桃臀| 日韩高清中文字幕在线| 日日躁夜夜躁久久狠狠躁| 国产精品一区二区三区在线| 九月丁香花开综合网| 国产亚洲一线二线三线| 欧美日韩综合精品无人区| 91精品国产自产永久在线| 最新日本欧美一区二区| 国产三级成人在线视频| 十八禁在线观看网址免费| 日韩一区二区偷拍视频| 国产丝袜在线福利观看|