JQuery animate 动画效果出现抖动的解决办法

起因:在做鼠标滑过商品缩略图,弹出“添加购物车”按钮的动画效果时,出现了动画闪烁的问题,后来发现是animate重复执行了。

解决办法:在animate方法前面加入stop()清空 防止重复执行。

例子:

$(" btn1").animate(top:'136px');

改为

$(" btn1").top().animate(top:'136px');

进一步:为鼠标经过事件添加延迟处理,即mouseenter()添加setTimeout();

var time = null;

$(".price_list1"). mouseenter (function() {
        var a =$(this).find('#btn1');
        timer = setTimeout(function(){
        a.stop().animate({top:'136px'},200);
        },300);        
    });
$(".price_list1").mouseleave (function(){
        var a =$(this).find('#btn1');
        if(timer){
            clearTimeout(timer);
        }
        a.animate({top:'161px'});
    });


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值