jQuery.animate简单分析

作者:heero 来源:heero博客 时间:2010-06-26 12:45:00 

很久之前就对jQuery.animate的实现非常感兴趣,不过前段时间很忙,直到前几天端午假期才有时间去研究。

jQuery.animate的每种动画过渡效果都是通过easing函数实现的。jQuery1.4.2中就预置了两个这样的函数:

easing: {
  linear: function( p, n, firstNum, diff ) {
    return firstNum + diff * p;
  },
  swing: function( p, n, firstNum, diff ) {
    return ((-Math.cos(p*Math.PI)/2) + 0.5) * diff + firstNum;
  }
}

从参数名隐约可以推测出firstNum是初始值。要是你的数学学得比较好,你可以发现linear函数是直线方程;要是你的物理学得比较好,你可以发现它是匀速运动的位移方程(我数学和物理都没学好,是别人提醒我的……)。那么diff和p就是速度和时间了。

再看看jQuery.animate的原型:

animate: function( prop, speed, easing, callback )

各参数的说明如下:

  • prop:一组包含作为动画属性和终值的样式属性和及其值的集合。

  • duration:动画时长。

  • easing:要使用的擦除效果的名称。

  • callback:动画完成时执行的函数。

元素的当前样式值(firstNum)可以获取,动画时长(p)就是duration,最终样式值是prop。理论上说,动画速度(diff)是可以算出来的。但是这又必然需要另一个函数进行运算。这样做明显是不明智的。再看看调用easing函数的相关代码(位于jQuery.fx.prototype.step中):

var t = now();
...
var n = t - this.startTime;
this.state = n / this.options.duration;
...
this.pos = jQuery.easing[specialEasing || defaultEasing](this.state, n, 0, 1, this.options.duration);

可以发现,p参数的值也就是this.state的值,从上下文得知它实际上是动画的时间进度。而firstNum和diff的参数值都是写死的,分别是0和1。这下easing函数的秘密完全被解开,p、firstNum、diff都是百分率而非实际数值,easing函数的返回值也就是位移的进度。diff的值是1,也就是以1倍的速度运行动画。算出位移进度后,通过“初始值+(最终值-初始值)×进度”就可以算出当前位移值:

this.now = this.start + ((this.end - this.start) * this.pos);

通过setInterval每隔一定时间(jQuery中是13ms)进行一次位移运算,直到当前时间与初始时间的差值大于动画时长,这就是jQuery.animate的执行过程。

按照常规思路,动画的实现方式是这样的:通过setInterval每隔一定时间给某个值增加特定数值,直到这个值达到限制值。这样做的主要问题是,不同浏览器的运行速度不同,从而导致动画速度有差异,一般是IE下比较慢,Firefox下比较快。而jQuery.animate是以当前时间来决定位移值,某个时刻的位移值总是固定的,因而动画速度不会有差异。

标签:jquery,jQuery.animate,动画
0
投稿

猜你喜欢

  • SQL2005 四个排名函数(row_number、rank、dense_rank和ntile)的比较

    2024-01-18 02:47:08
  • 浅谈MySQL大表优化方案

    2024-01-26 06:20:37
  • MySQL对window函数执行sum函数可能出现的一个Bug

    2024-01-23 23:37:42
  • 关于SQL Update的四种常见写法

    2024-01-25 09:40:07
  • Python数据分析入门之教你怎么搭建环境

    2023-03-15 12:21:11
  • js版sliderBar(滑动条)控件

    2008-10-18 15:59:00
  • js删除所有的cookie的代码

    2024-05-02 17:29:59
  • 值得收藏的9个提高代码运行效率的小技巧(推荐)

    2022-08-01 04:13:05
  • 基于numpy中数组元素的切片复制方法

    2023-07-24 03:14:41
  • PHP的PDO事务与自动提交

    2023-06-09 02:32:55
  • 使用Python脚本实现批量网站存活检测遇到问题及解决方法

    2022-04-12 00:50:03
  • JavaScrpt的面向对象全面解析

    2024-04-23 09:20:40
  • Python中asyncio模块的深入讲解

    2022-05-18 22:33:53
  • Python np.where()的详解以及代码应用

    2023-02-15 18:33:01
  • Javascript: 为<input>设置readOnly属性问题,希望大家以后要小心

    2009-07-23 20:24:00
  • CentOS 7中源码安装MySQL 5.7.6+详细教程

    2024-01-24 13:12:27
  • golang-redis之sorted set类型操作详解

    2024-02-02 05:19:20
  • ubuntu lamp(apache+mysql+php) 环境搭建及相关扩展更新

    2023-10-16 03:26:55
  • pip安装库报错[notice] A new release of pip available: 22.2 -> 22.2.2

    2021-07-15 15:57:04
  • 灵活运用Python 枚举类来实现设计状态码信息

    2023-04-29 15:03:34
  • asp之家 网络编程 m.aspxhome.com