js 數字遞增特效 仿支付寶我的財富 HTML5


上周五應着公司臨時需求,一天的時間解決掉官網(ps:比較簡單哈哈),需求里面有一個特效就是數字遞增到指定的數值,其實JS寫也不復雜的,但是我發現一個js小插件,這個插件輕巧簡單,用起來也非常簡單實用。在這里分享給小盆友們吧,喜歡的直接拿走。

ion

上面就是這個插件的效果,我們來看一下怎么使用的吧

第一: HTML部分這里簡單列舉一個

 <div class="counter col_fourth">
     <h2 class="timer count-title" id="count-number" data-to="300" data-speed="1500"></h2>
     <p class="count-text ">小月博客</p>
 </div>

 

上面我們來了解兩個關鍵的東西:

  • data-to   這個屬性控制你最終要遞增的數值是多少
  • data-speed    這個看英文的意思就很清楚了就是表示數據遞增的速度了

ps: 這里的class和id  根據大家各自的修改去調整就好了,

第二:JS部分也是插件的核心代碼

$.fn.countTo = function(a) {
     a = a || {};
     return $(this).each(function() {
         var c = $.extend({},
         $.fn.countTo.defaults, {
             from: $(this).data("from"),
             to: $(this).data("to"),
             speed: $(this).data("speed"),
             refreshInterval: $(this).data("refresh-interval"),
             decimals: $(this).data("decimals")
         }, a);
     var h = Math.ceil(c.speed / c.refreshInterval),
     i = (c.to - c.from) / h;
     var j = this,
     f = $(this),
     e = 0,
     g = c.from,
     d = f.data("countTo") || {};
     f.data("countTo", d);
     if (d.interval) {
         clearInterval(d.interval)
     }
     d.interval = setInterval(k, c.refreshInterval);
     b(g);
     function k() {
         g += i;
         e++;
         b(g);
         if (typeof(c.onUpdate) == "function") {
             c.onUpdate.call(j, g)
         }
         if (e >= h) {
             f.removeData("countTo");
             clearInterval(d.interval);
             g = c.to;
             if (typeof(c.onComplete) == "function") {
                 c.onComplete.call(j, g)
             }
         }
     }
     function b(m) {
         var l = c.formatter.call(j, m, c);
         f.html(l)
     }
 })
};
$.fn.countTo.defaults = {
     from: 0,
     to: 0,
     speed: 1000,
     refreshInterval: 100,
     decimals: 0,
     formatter: formatter,
     onUpdate: null,
     onComplete: null
};
function formatter(b, a) {
     return b.toFixed(2)
}
$("#count-number").data("countToOptions", {
     formatter: function(b, a) {
         return b.toFixed(2).replace(/\B(?=(?:\d{3})+(?!\d))/g, ",")
     }
});
$(".timer").each(count);
function count(a) {
     var b = $(this);
     a = $.extend({},
     a || {},
     b.data("countToOptions") || {});
     b.countTo(a)
};

 

以上就是代碼的全部了,css部分就不在這里顯示了,demo下載的小伙伴在下面點擊下載吧!

其實這個插件可擴展性很大的,至於小伙伴喜歡什么樣子的顯示自己動手改造吧!

 

demo下載請點擊

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM