我遇到了一个非常烦人的错误,它出现在 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
它才出现。
现在,鉴于我假设它与触发另一个转换有关,我尝试通过 JavascriptsetInterval
翻转元素上的类,使其来回转换,从而强制转换每秒发生一次。但这并没有解冻过渡并使其#chance-card
出现。转换 atransform: translate
而不是margin-left
on#chance-card
也无济于事。
如 JSFiddle 中所述,减少transition-delay
on#chance-card
确实会使错误消失,但对于我的用例来说,这不是一个可接受的解决方案。
我想知道是否有人可以提出任何解决方法?在我的搜索中,我没有找到任何听起来相似的东西。