Я не знаю почему, но кажется, что animate () в функции hover «out» начинается со значения 0
вместо 16
, которое должно быть установлено функцией hover «in»:
$.fx.step.textShadowBlur = function(fx) {
$(fx.elem).css({textShadow: '0 0 ' + Math.floor(fx.now) + 'px #000'});
};
$('a').hover(function(){
$(this).stop().animate({textShadowBlur:16}, {duration: 400});
}, function(){
$(this).stop().animate({textShadowBlur:0}, {duration: 900});
});
Таким образом, я получаю резкое изменение тени текста при отсутствии мыши
Что я делаю неправильно?
jsfiddle
хорошо, я исправил это.Кажется, это ошибка jquery с определением функции шага или что-то в этом роде.В любом случае это будет работать:
$('a').hover(function(){
$(this).stop().animate({nothing:16}, {duration: 400, step: function(now, fx){
$(this).css({textShadow: '0 0 ' + Math.floor(fx.now) + 'px #000'});
}});
}, function(){
$(this).stop().animate({nothing:0}, {duration: 900, step: function(now, fx){
$(this).css({textShadow: '0 0 ' + Math.floor(fx.now) + 'px #000'});
}});
});