57.时间版运动框架2

新建一个对象,把另一个对象的属性和处理过的属性值赋值给该对象

 传进去json对象:

先将 startJson speedJson声明成对象,for in 传进来的targetJson,分别给startJson speedJson赋值

 

还可传回调函数(callback)

最后运用短路运算符,决定执不执行callback函数

  bind与call apply 的区别是 bind不能传递第二个参数,且不能执行,因此用变量来接受,然后采用变量() 的形式来执行

回调函数体内使用 此时this指向window

此时this指向dom,并且call会自执行函数

会弹出四次1,因为每个属性放在for in循环里,虽说时间运动框架时间一致,但是for in循环四次也是有个先后顺序,时间不可能完全一致,因此会打印四次。

解决方法,把清除定时器与回调函数放在for in循环外面,放在时间判断里

此外,如果目标值是小于初始值的情况,那么判断条件 也不能是 if getStyle[dom,key]>targetJson[key] 也要换成是时间判断:

实现效果:变成目标值后回到最初的样式:利用回调函数

call 执行可以用this

 改进:

单独把animation函数 放进js就是时间运动框架,用户自己决定有无回调函数,以及什么样的回调函数。

原文地址:https://www.cnblogs.com/yzdwd/p/12641759.html