16

我正在显示title链接的属性:hover。标题属性通过:after...附加到链接中</p>

现在我想知道如何:after在悬停和悬停时为伪元素的不透明度设置动画。

html

<a class="link" href="#" title="something"></a>​

css

.link {
    display:block;
    width:50px;
    height:50px;
    background:red;
}

.link:after {
    position:relative; 
    content: attr(title); 
    top:55px; 
    color:$blue; 
    zoom: 1; 
    filter: alpha(opacity=00); 
    opacity: 0;
    -webkit-transition: opacity .15s ease-in-out;
    -moz-transition: opacity .15s ease-in-out;
    -ms-transition: opacity .15s ease-in-out;
    -o-transition: opacity .15s ease-in-out;
    transition: opacity .15s ease-in-out;
}

.link:hover:after { 
    zoom: 1; 
    filter: alpha(opacity=100); 
    opacity: 1;
}

查看演示:http: //jsfiddle.net/d2KrC/

任何想法为什么这不起作用?​</p>

4

2 回答 2

10

WebKit (Chrome, Safari) 不支持伪元素的过渡。

它应该在 Firefox 中工作。

编辑: WebKit中的问题现已解决。该补丁已经登陆 Chrome Carnery,因此将从版本 26 开始支持。我不知道Safari。

于 2012-05-14T06:58:03.340 回答
5

这个 webkit 错误有一个相当简单的解决方法,可以使转换在伪类上工作。这是一篇很棒的博客文章:http: //xiel.de/webkit-fix-css-transitions-on-pseudo-elements/

基本上 webkit 不直接支持过渡,但您可以将要更改的过渡和样式应用到其父元素。然后在伪类中放置您想要影响的相同样式属性,但给它们值:继承。这将导致它们继承所有父元素值,包括过渡。

这是我为 :after 元素上下动画制作的示例

a { 
    position: static; /* explicitly defined so not to forget that it can't be relative or :after transition hack will not work */
    top: 1px; /*doesnt move it because it is position static */
    -webkit-transition: top 200ms ease 0;
}
a:after {
    content: '';
    position: absolute;
    top: inherit;
}
a:hover {
    top: 3px;
}

*更新该错误已在 Chrome Canary 中得到修复(截至 2 月),但在 Safari 中似乎仍然存在问题。可以在这里查看状态并保持更新: https ://code.google.com/p/chromium/issues/detail?id=54699

于 2012-12-16T20:51:52.680 回答