如何防止 Safari css 关键帧动画闪烁?

Mat*_*t M 4 css safari css-animations

我已经尝试了从添加额外的关键帧(0%、1%、100% 或 0%、99%、100%)到设置 -webkit-animation-fill-mode 以转发到经常提到的 -webkit-backface-可见性:隐藏;在其他线程中提到的技巧,但在 Safari 7(桌面和 iOS)中几乎每个动画迭代开始时,我仍然看到我的 css 关键帧动画闪烁。Chrome 似乎没有闪烁。

JSBin:http : //jsbin.com/julor/2/edit

HTML:

<div class="ripple"></div>
Run Code Online (Sandbox Code Playgroud)

CSS:

body {
  background-color: #90CBEA;
}

.ripple, .ripple:before, .ripple:after {
  background-image: radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, .15) 100%);

  border-radius: 50%;
  position: absolute;
  top: 50%; left: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
}

.ripple:before, .ripple:after {
  content: '';
  display: block; 
}

.ripple {
  -webkit-animation-name: innerRipple;
  -webkit-animation-duration: 3s;
  -webkit-animation-iteration-count: infinite;
  -webkit-animation-timing-function: ease-out;

  &:before {
    -webkit-animation-name: ripple;
  -webkit-animation-duration: 3s;
  -webkit-animation-iteration-count: infinite;
  -webkit-animation-timing-function: ease-out;
  }

  &:after {
    -webkit-animation-name: outerRipple;
  -webkit-animation-duration: 3s;
  -webkit-animation-iteration-count: infinite;
  -webkit-animation-timing-function: ease-out;
  }
}

@-webkit-keyframes innerRipple {
  from {
    height: 0px;
    width: 0px;
    opacity: 1;
  }

  to {
    height: 200px;
    width: 200px;
    opacity: 0;
  }
}

@-webkit-keyframes ripple {
  from {
    height: 0px;
    width: 0px;
    opacity: 1;
  }

  to {
    height: 300px;
    width: 300px;
    opacity: 0;
  }
}

@-webkit-keyframes outerRipple {
  from {
    height: 0px;
    width: 0px;
    opacity: 1;
  }

  to {
    height: 340px;
    width: 340px;
    opacity: 0;
  }
}
Run Code Online (Sandbox Code Playgroud)

Wou*_*and 5

在比 99% 稍早一点的时候在中间添加一个帧使得 Safari 上的闪烁消失了!(Safari 8 OS X)

@-webkit-keyframes innerRipple {
  0% { height: 0px; width: 0px; opacity: 1; }
  95% { height: 200px; width: 200px; opacity: 0; }
  100% { width: 0px; height: 0px; opacity: 0; }
}

@-webkit-keyframes ripple {
  0% { height: 0px; width: 0px; opacity: 1; }
  95% { height: 300px; width: 300px; opacity: 0; }
  100% { width: 0px; height: 0px; opacity: 0; }
}

@-webkit-keyframes outerRipple {
  0% { height: 0px; width: 0px; opacity: 1; }
  95% { height: 340px; width: 340px; opacity: 0; }
  100% { width: 0px; height: 0px; opacity: 0; }
}
Run Code Online (Sandbox Code Playgroud)