js实现数字递增特效【仿支付宝我的财富】


Posted in Javascript onMay 05, 2017

上周五应着公司临时需求,一天的时间解决掉官网(ps:比较简单哈哈),需求里面有一个特效就是数字递增到指定的数值,其实JS写也不复杂的,但是我发现一个js小插件,这个插件轻巧简单,用起来也非常简单实用。在这里分享给小盆友们吧,喜欢的直接拿走。

js实现数字递增特效【仿支付宝我的财富】

上面就是这个插件的效果,我们来看一下怎么使用的吧

第一: 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下载请点击

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JavaScript的eval JSON object问题
Nov 15 Javascript
Javascript和HTML5利用canvas构建Web五子棋游戏实现算法
Jul 17 Javascript
使用bootstrap3开发响应式网站
May 12 Javascript
HTML5+jQuery插件Quicksand实现超酷的星际争霸2兵种分类展示效果(附demo源码下载)
May 25 Javascript
JS禁止查看网页源代码的实现方法
Oct 12 Javascript
微信小程序 首页制作简单实例
Apr 07 Javascript
Angular 4依赖注入学习教程之FactoryProvider配置依赖对象(五)
Jun 04 Javascript
vue-resource调用promise取数据方式详解
Jul 21 Javascript
浅谈使用React.setState需要注意的三点
Dec 18 Javascript
利用weixin-java-miniapp生成小程序码并直接返回图片文件流的方法
Mar 29 Javascript
vue实现路由不变的情况下,刷新页面操作示例
Feb 02 Javascript
JavaScript实现H5接金币功能(实例代码)
Feb 22 Javascript
js和jquery中获取非行间样式
May 05 #jQuery
值得分享和收藏的xmlplus组件学习教程
May 05 #Javascript
微信小程序中多个页面传参通信的学习与实践
May 05 #Javascript
微信小程序 开发之全局配置
May 05 #Javascript
jquery实现tab选项卡切换效果(悬停、下方横线动画位移)
May 05 #jQuery
微信小程序 图片上传实例详解
May 05 #Javascript
微信小程序实现登录页云层漂浮的动画效果
May 05 #Javascript
You might like
php中session_unset与session_destroy的区别分析
2011/06/16 PHP
一个漂亮的php验证码类(分享)
2013/08/06 PHP
你可能不知道PHP get_meta_tags()函数
2014/05/12 PHP
使用纯php代码实现页面伪静态的方法
2015/07/25 PHP
Discuz!X中SESSION机制实例详解
2015/09/23 PHP
跟我学Nodejs(三)--- Node.js模块
2014/05/25 NodeJs
jQuery中innerHeight()方法用法实例
2015/01/19 Javascript
jQuery实现手机号码输入提示功能实例
2015/04/30 Javascript
JS更改select内option属性的方法
2015/10/14 Javascript
Bootstrap中定制LESS-颜色及导航条(推荐)
2016/11/21 Javascript
JS中用EL表达式获取上下文参数值的方法
2018/03/28 Javascript
详解Vue.js中.native修饰符
2018/04/24 Javascript
element ui 表格动态列显示空白bug 修复方法
2018/09/04 Javascript
基于vue-cli3和element实现登陆页面
2019/11/13 Javascript
原生js实现碰撞检测
2020/03/12 Javascript
jQuery AJAX应用实例总结
2020/05/19 jQuery
ant design vue导航菜单与路由配置操作
2020/10/28 Javascript
微信小程序实现简单购物车功能
2020/12/30 Javascript
[02:52]2017DOTA2国际邀请赛中国区预选赛晋级之路
2017/07/03 DOTA
python 获取本机ip地址的两个方法
2013/02/25 Python
使用Python的web.py框架实现类似Django的ORM查询的教程
2015/05/02 Python
python获取当前运行函数名称的方法实例代码
2017/04/06 Python
Python基于socket实现简单的即时通讯功能示例
2018/01/16 Python
Python及Django框架生成二维码的方法分析
2018/01/31 Python
PyTorch使用cpu加载模型运算方式
2020/01/13 Python
在Python中实现字典反转案例
2020/12/05 Python
ECCO爱步美国官网:来自丹麦的鞋履品牌
2016/11/23 全球购物
学生个人的自我评价分享
2013/11/05 职场文书
2015年度优秀员工推荐信
2015/03/23 职场文书
工地材料员岗位职责
2015/04/11 职场文书
2015社区健康教育工作总结
2015/05/20 职场文书
幼儿园心得体会范文
2016/01/21 职场文书
Vue和Flask通信的实现
2021/05/19 Vue.js
python实现语音常用度量方法的代码详解
2021/05/25 Python
Python 如何利用ffmpeg 处理视频素材
2021/11/27 Python
java实现web实时消息推送的七种方案
2022/07/23 Java/Android