欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用JS實(shí)現(xiàn)數(shù)字增長

 更新時(shí)間:2016年07月28日 17:26:26   投稿:daisy  
做項(xiàng)目時(shí)候常常遇到,要做一個(gè)數(shù)字滾動增加的效果。如何利用JavaScript實(shí)現(xiàn)數(shù)字增長效果,一起來跟本文學(xué)習(xí)學(xué)習(xí)。

上次在項(xiàng)目中碰到要實(shí)現(xiàn)數(shù)字增長的效果,實(shí)現(xiàn)數(shù)字從0到目標(biāo)數(shù)的增長,來看看效果圖

現(xiàn)在把它擴(kuò)展開來可以實(shí)現(xiàn)不同效果

主要思路就兩部分

    1.每隔三個(gè)數(shù)字之間加上,

    2.實(shí)現(xiàn)動起來

對于1使用正則來完成十分的方便

this.fomatNum = function(num) {
      var str = num.toFixed(this.option.decimal);//精確到小數(shù)位數(shù)多少位
      var num1, x1, x2, reg;
      arr = str.split(".");
      x1 = arr[0];
      x2 = arr.length > 1 ? '.' + arr[1] : "";
      reg = /(\d+)(\d{3})/;
      if (this.option.isfomat) {
        while (reg.test(x1)) {
          x1 = x1.replace(reg, '$1' + "," + "$2");
        }
      }
      if (this.option.isfomat) {
        return this.option.prefix + x1 + x2;
      } else {
        return this.option.prefix + str;
      }
    }

要實(shí)現(xiàn)加起來的效果可以使用requestAnimationFrame方法,然后處理一下兼容就可以了。

var change = function() {
  var p = Math.min(1.0, (new Date().getTime() - that.startTime) / that.option.duration);//當(dāng)前時(shí)間減去開始時(shí)間,然后除以總時(shí)間,Math.min,兩個(gè)數(shù)取最小值。
  var nums = that.num * p;
  that.elm.innerHTML = that.fomatNum(that.num * p);
  if (p < 1.0) {//
     requestAnimationFrame(function() {
        change();
     });
   } else {
        cancelAnimationFrame(change);
       }
  }
  requestAnimationFrame(function() {
     change();
   });

如果要實(shí)現(xiàn)數(shù)字在可視區(qū)再動起來的效果,可以自己監(jiān)聽dom是否在可視區(qū)然后調(diào)用。

以上就是本文的全部內(nèi)容,如果有疑問歡迎大家留言探討,也謝謝大家對腳本之家的支持。

相關(guān)文章

最新評論