当我尝试用纯CSS进行简单转换时,一切都很好
但是,当我试图调用一个javascript函数来修改单击链接时的CSS时,没有转换。我想在灰色的层次上褪色。
HTML:
<a href="someImage.jpg" id="test">
<img src="someImage.jpg" alt="" />
</a>
<section id="grey">
</section>
JS:
var grey = document.getElementById("grey");
var link = document.getElementById("test");
link.onclick = function () {
grey.style.display = "block";
grey.style.opacity = "1";
return false;
};
CSS:
section {
display:none;
size and position...
opacity: 0;
background-color: rgba(0,0,0,0.5);
transition: opacity 1s .5s;
}
(参见http://jsfiddle.net/7zEhx/5/)
我用的是FF22,有人知道解决方案吗?
display: none
元素不会转换,在设置其他样式之前,display: block
也没有启动。有这样可怕的黑客:
setTimeout(function() {
grey.style.opacity = "1";
}, 0);
但我只是将width
设置为0
,而不是设置display
,然后将其放回100%
更新的jsFiddle