原理介绍
抖动其实是往复运动的一种特殊形式,只不过往复运动是一种无摩擦力的无限运动,且以速度为参照依据;而抖动以位置作为参照依据,最终停在起始点
在网页中最常见的一种抖动效果应该是窗口抖动提示了
抖动元素从起始点开始,先向右移动最大距离len,然后移动到对称的左边位置;然后再向右移动稍微小一点的距离,再移动到对称的左边位置;以此循环,最终元素停止在起始点
代码实现
抖动在代码实现上,无非就是通过定时器,每隔一段时间让left或top值进行变化
在运动实现中,有两种距离变化的思路
思路一
div.style.left = div.offsetLeft + value;
每次都获取元素的当前样式,再与变化的value值进行运算
思路二
left = div.offsetLeft;
......
div.style.left = left + value;
在定时器开启之前,获取元素的初始样式,再与变化的value值进行运算
从抖动实现上来说,使用第二种方法,把距离变化完全交给value值变化来实现较为简单
所以,代码实现的关键就是了解value是如何变化的
假设最远距离为目标target&#x