html animation 无限循环,javascript – 如何创建一个有效的无限循环挥动文本动画?...

这是我试图创建的效果(

JSFiddle):

$('.header h1 span').each(function() { // each letter is contained inside a element

var that = $(this);

setTimeout(function() {

that.animate({

top: "-10px"

},animateTime / 2)

.animate({

top: "10px"

},animateTime / 2);

},that.index() * 100);

});

结果:

12d519031d4e19d9c77465373b9b92e7.gif

它似乎很成功.但是,在切换标签后,我遇到了这样的问题,然后又回来了:

6c5b16e850a488fe02714ab4e1fae05a.gif

在上面的小提琴中,我试图通过在选项卡未聚焦时停止动画来“修复”这个问题.这比我没有检查标签无焦点时更好,但它仍然有问题.这是我用来做的代码:

var running = true;

document.addEventListener('visibilitychange',function(){

console.log("Running:" + running);

running = !document.hidden;

if(!running) clearQueues();

})

如果用户从标签中花费的时间不到几秒钟,动画看起来就像是第二个GIF,我没有办法避免这种情况.我尝试过使用requestAnimationFrame(),但我无法弄清楚如何使其正常运行.

所以,我的问题是:如何防止动画受到未聚焦选项卡的影响?

奖励积分(比喻)如果你能帮我在移动设备上提高效率的话.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值