2
我創建了一個模擬情況,因爲我無法輕鬆創建可測試版本。但要獲得要點:帶父變換的CSS變換在iOS上無效Safari
@keyframes mainFadeIn {
0% {
opacity: 0;
transform: translateY(-3rem);
}
100% {
opacity: 1;
transform: translateY(0);
}
}
// If I use this, without the transform, then everything works.
//
// @keyframes mainFadeIn {
// 0% {
// opacity: 0;
// }
//
// 100% {
// opacity: 1;
// }
// }
.main {
animation-name: mainFadeIn;
animation-duration: 1s;
animation-fill-mode: both;
animation-timing-function: linear;
background-color: gray;
width: 100%;
height: 16rem;
padding: 3rem;
}
.card {
transition: transform 500ms;
transform-style: preserve-3d;
-webkit-transform-origin: 50% 50%;
perspective: 200px; // Ignore
margin: auto;
width: 30rem;
height: 10rem;
background-color: lightblue;
&.flipped {
transform: rotateY(-180deg);
}
}
.front,
.back {
backface-visibility: hidden;
}
.back {
transform: rotateY(-180deg);
}
<div class="main">
<div class="card">
<div class="front"></div>
<div class="back"></div>
</div>
</div>
希望這足以知道哪裏有問題。
CodePen: https://codepen.io/anon/pen/owvqQP/
編輯 嘛。這可能是這件事:css z-index lost after webkit transform translate3d
但我仍然無法得到它的工作。唯一的解決方案是使用position: relative;
和top: 0;
和top: -3rem;
作爲動畫。
你的ios safari的版本是什麼? – karthick
iOS 9.2.1是操作系統版本。 – Steve