Jquery中的随机数效应

Jac*_*nto 2 html css jquery animation

我被卡住了.我试图让jquery在页面加载时使用数字生成动画.因此,数字5将在0-9之间切换,直到分配的时间结束,或者如果我有50,则5将经历0-9,0也将经历0-9.

谢谢大家的答案和建议.

sim*_*aun 12

我很闷.这里:

(function($){
    $.fn.extend({
        numAnim: function(options) {
            if ( ! this.length)
                return false;

            this.defaults = {
                endAt: 2560,
                numClass: 'autogen-num',
                duration: 5,   // seconds
                interval: 90  // ms
            };
            var settings = $.extend({}, this.defaults, options);

            var $num = $('<span/>', {
                'class': settings.numClass 
            });

            return this.each(function() {
                var $this = $(this);

                // Wrap each number in a tag.
                var frag = document.createDocumentFragment(),
                    numLen = settings.endAt.toString().length;
                for (x = 0; x < numLen; x++) {
                    var rand_num = Math.floor( Math.random() * 10 );
                    frag.appendChild( $num.clone().text(rand_num)[0] )
                }
                $this.empty().append(frag);

                var get_next_num = function(num) {
                    ++num;
                    if (num > 9) return 0;
                    return num;
                };

                // Iterate each number.
                $this.find('.' + settings.numClass).each(function() {
                    var $num = $(this),
                        num = parseInt( $num.text() );

                    var interval = setInterval( function() {
                        num = get_next_num(num);
                        $num.text(num);
                    }, settings.interval);

                    setTimeout( function() {
                        clearInterval(interval);
                    }, settings.duration * 1000 - settings.interval);
                });

                setTimeout( function() {
                    $this.text( settings.endAt.toString() );
                }, settings.duration * 1000);
            });
        }
    });
})(jQuery);
Run Code Online (Sandbox Code Playgroud)

测试HTML:

<span id="number"></span>
Run Code Online (Sandbox Code Playgroud)

用法:

$("#number").numAnim({
    endAt: 97855,
    duration: 3
});
Run Code Online (Sandbox Code Playgroud)