jQuery动画CSS,设置回悬停状态

Posted

技术标签:

【中文标题】jQuery动画CSS,设置回悬停状态【英文标题】:jQuery animate CSS, set back hover state 【发布时间】:2011-05-01 03:09:31 【问题描述】:

我有一个更新按钮,我想在更新我的内容时引起注意。我正在使用动画颜色渐变并添加一些箭头字符来执行此操作。

动画完成后,我希望我的 CSS :hover 状态返回。 这是可能的还是我丢失了原始的 CSS 并且我必须用 jQuery 的hover() 重置这些@

小提琴:http://jsfiddle.net/K6fd2/

CSS

a.btn  padding: 5px 20px; color: white; background-color: #4188FB;  
a.btn:hover  background: #FFCC00;

html

<a href="#" class="btn">Update</a>
<br /><br />
<a href="#" class="change">change content</a>

JS

var oriBtnTxt = $(".btn").html(); // store original text

$(".change").click(function() 
    $(".btn")
    .css("background-color","#FFCC00")
    .html(oriBtnTxt + " &raquo;")
    .animate(backgroundColor: "#4188FB", 2000, "swing", function() 
        // set back hover state
        $("a.btn:hover").css("background-color", "#FFCC00");
    );
)

【问题讨论】:

【参考方案1】:

这可能不是最优雅的解决方案,但您可以尝试以下方法:

$(this).removeAttr('style');

在您的 $.animate() 回调函数中。

编辑:我怀疑您正在丢失您的:hover 样式,因为$.animate() 使用内联样式,这些样式是在评估样式表规则之后设置的;因此它们优先于样式表中定义的样式。

【讨论】:

以上是关于jQuery动画CSS,设置回悬停状态的主要内容,如果未能解决你的问题,请参考以下文章

jQuery 将背景图像设置为菜单悬停状态和菜单活动状态

如何使用 jQuery 动画化 css 的变化

使用jQuery动画远离光标时,停止“:悬停”元素保持其状态?

jQuery - 具有悬停效果的多个项目

jQuery CSS 悬停

jQuery - 找出:悬停样式