PHP前端开发

如何使用插件数字滚动插件numberAnimate.js?

百变鹏仔 3个月前 (10-18) #H5教程
文章标签 插件

本篇文章给大家带来的内容是关于如何使用插件数字滚动插件numberanimate.js?有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

有个实现数字滚动的需求,想着肯定有很多这种效果的插件,就不自己造轮子了,于是,找了个numberAnimate js数字滚动插件,还挺好用,很简单,刚好符合需求。

代码如下:

<!DOCTYPE html><html lang="en">    <head>        <meta charset="utf-8">        <title>数字滚动插件</title>        <link rel="stylesheet" type="text/css" href="../dist/style/numberAnimate.css" />    </head>    <body>    无分隔符,无小数点:<p class="numberRun"></p><br><br>    </body>    <script src="http://cdn.bootcss.com/jquery/1.8.3/jquery.min.js"></script>    <script type="text/javascript" src="../dist/script/numberAnimate.js"></script>    <script type="text/javascript">    $(function(){        //初始化        var numRun = $(".numberRun").numberAnimate({num:&#39;1553093&#39;, speed:1000});        //想要的是过一段时间加1的效果,可以实现        var nums = 1553093;        setInterval(function(){            nums+= 1;            numRun.resetData(nums);        },2000);    })</script></html>

想要的效果是过一段时间加1的效果,可以实现,但是有个小小的bug,那就是,比如说,个位数字加到9时进一位然后该位上为0,问题来了,这里0的数字却滚动不出来,直接到了下一个时间间隔时滚动到了11,调试了很久发现,是numberAnimate.js中,第85行的判断条件有问题,注释掉该if判断就好了,如下图:

上图中,第85行的$(this).css("top")一直都是0px,而第84行计算获取到的thisTop 在数字滚到到0 时值为0px,所以导致直接跳过了判断,没有执行到transform动画那里,所以少了0的效果,导致看起来的效果就是9直接跳到了11,没有10。

另外,提示一句,改变数字的字号大小,需要修改的numberAnimate.css中的height、width、字号的比例要把握好,一不小心就坏了,亲身体会 -_-||