我有这段代码,它在 mouseenter 上将一些图标淡化为不透明度 1.0,在 mouseleave 上淡化为 0.3。它工作得很好,除了我在不同的响应视图中将这些图标设置为不透明度 0.13,但下面的代码仍然将它们淡化回 0.3 而不是鼠标移出时的 0.13,这不是我想要的。
$(".social-holder img").on("hover", function(e) {
if(e.type == "mouseenter") {
$(this).fadeTo('fast', 1.0);
}
else if (e.type == "mouseleave") {
$(this).fadeTo('fast', 0.3);
}
});
我尝试了下面的代码,但我不明白为什么它不起作用。它在 mouseleave 上将图标留在 1.0
$(".social-holder img").on("hover", function(e) {
var currentOpacity = $(this).css('opacity');
if(e.type == "mouseenter") {
$(this).fadeTo('fast', 1.0);
}
else if (e.type == "mouseleave") {
$(this).fadeTo('fast', currentOpacity);
}
});
顺便说一句,当我使用控制台检查时,var currentOpacity 似乎工作正常,但它似乎没有进入 else if 语句。也许我对范围或其他东西有一些误解。