【发布时间】:2013-09-16 08:07:25
【问题描述】:
我遇到了一个非常烦人的错误,它出现在 Mac 上的 Safari 5.1 中。由于这个浏览器还是很常见的,所以需要支持一下。
JSFiddle:http://jsfiddle.net/QCvZt/2/
单击按钮时,将向包含元素#chance 添加一个类。样式表的规则会导致被点击的元素 #chance-loose-card 立即以动画形式消失,然后在延迟之后,#chance-card 以动画形式进入。
它们淡出并使用opacity 淡入,当它们完全透明时我将visibility 翻转为隐藏,因为在整个站点中,它们可能会超出事物的顶部并捕获针对下面元素的点击。
这在 Firefox 和 Chrome(以及 Safari 6)中运行良好。
但在 Mac 上的 Safari 5.1 中,第一个动画按预期发生,但随后 #chance-card 没有出现。直到我将鼠标悬停在#carousel 元素上(可能是因为它触发了另一个过渡——一个淡入的按钮),#chance-card 才出现。
现在,鉴于我假设它与触发另一个转换有关,我尝试通过 Javascript setInterval 翻转元素上的类,使其来回转换,从而强制转换每秒发生一次。但这并没有解冻过渡并使#chance-card 出现。在#chance-card 上转换transform: translate 而不是margin-left 也无济于事。
如 JSFiddle 中所述,减少 #chance-card 上的 transition-delay 确实可以消除错误,但对于我的用例来说,这不是一个可接受的解决方案。
我想知道是否有人可以提出任何解决方法?在我的搜索中,我没有找到任何听起来相似的东西。
【问题讨论】: