如何在时间间隔内翻转 div

  • 本文关键字:翻转 div 时间 html css
  • 更新时间 :
  • 英文 :


嗨,请看一下这个脚本,告诉我如何按时间间隔翻转 A B 和 Cdiv。我希望 A 先翻转然后停止,B 接下来翻转并停止,C 接下来又回到 A、B 和 C,就像循环一样,重新开始。这在 CSS3 中可能吗?在此代码中,所有div 同时翻转。

/* ::: HOLDER, CARD, FACES */
.holder {
  display:     inline-block;
  width:       64px;
  height:      64px;
  perspective: 700px;
}
.card, .front, .back{
  position:   absolute;
  height:     inherit;
  width:      inherit;
  transition: all .7s;
  transform-style:     preserve-3d;
  backface-visibility: hidden;
}
/* ::: FACES */
.front{background: tomato;}
.back{background:  slategray;}
/* ::: SETUP FACES */
.flipH .back{transform: rotateY(-180deg);}
.flipV .back{transform: rotateX(180deg);}
/* ::: HOVER EFFECTS (Remove Automated for this to work) */
.flipH:hover .card{ transform: rotateY(180deg); }
.flipV:hover .card{ transform: rotateX(-180deg); }
/* ::: AUTOMATED EFFECTS */
.flipH .card{
  animation: flipH 2s 0s infinite alternate ease-in-out;
  -webkit-animation: flipH 2s 0s infinite alternate ease-in-out;
}
.flipV .card{
  animation: flipV 2s 0s infinite alternate ease-in-out;
  -webkit-animation: flipV 2s 0s infinite alternate ease-in-out;
}
@keyframes flipH {
  0% { transform: rotateY(0deg); }
  100% { transform: rotateY(-180deg); }
}
@-webkit-keyframes flipH {
  0% { transform: rotateY(0deg); }
  100% { transform: rotateY(-180deg); }
}
@keyframes flipV {
  0% { transform: rotateX(0deg); }
  100% { transform: rotateX(-180deg); }
}
@-webkit-keyframes flipV {
  0% { transform: rotateX(0deg); }
  100% { transform: rotateX(-180deg); }
}
<div class="holder flipH">
  <div class="card">
    <div class="front">A</div>
    <div class="back">A</div>
  </div>
</div>
<div class="holder flipV">
  <div class="card">
    <div class="front">B</div>
    <div class="back">B</div>
  </div>
</div>
<div class="holder flipH">
  <div class="card">
    <div class="front">C</div>
    <div class="back">C</div>
  </div>
</div>

正如麦迪所说,动画延迟是诀窍

/* ::: HOLDER, CARD, FACES */
.holder {
  display:     inline-block;
  width:       64px;
  height:      64px;
  perspective: 700px;
}
.card, .front, .back{
  position:   absolute;
  height:     inherit;
  width:      inherit;
  transition: all .7s;
  transform-style:     preserve-3d;
  backface-visibility: hidden;
}
/* ::: FACES */
.front{background: tomato;}
.back{background:  slategray;}
/* ::: SETUP FACES */
.flipH .back{transform: rotateY(-180deg);}
.flipV .back{transform: rotateX(180deg);}
/* ::: HOVER EFFECTS (Remove Automated for this to work) */
.flipH:hover .card{ transform: rotateY(180deg); }
.flipV:hover .card{ transform: rotateX(-180deg); }
/* ::: AUTOMATED EFFECTS */
.flipH .card{
  animation: flipH 3s 0s infinite alternate ease-in-out;
  -webkit-animation: flipH 3s 0s infinite alternate ease-in-out;
}
.flipV .card{
  animation: flipV 3s 1s infinite alternate ease-in-out;
  -webkit-animation: flipV 3s 1s infinite alternate ease-in-out;
}
.flipH:nth-child(3) .card {
    -webkit-animation-delay: 2s;
    animation-delay: 2s;
}
@keyframes flipH {
  0% { transform: rotateY(0deg); }
  100% { transform: rotateY(-180deg); }
}
@-webkit-keyframes flipH {
  0% { transform: rotateY(0deg); }
  100% { transform: rotateY(-180deg); }
}
@keyframes flipV {
  0% { transform: rotateX(0deg); }
  100% { transform: rotateX(-180deg); }
}
@-webkit-keyframes flipV {
  0% { transform: rotateX(0deg); }
  100% { transform: rotateX(-180deg); }
}
<div class="holder flipH">
  <div class="card">
    <div class="front">A</div>
    <div class="back">A</div>
  </div>
</div>
<div class="holder flipV">
  <div class="card">
    <div class="front">B</div>
    <div class="back">B</div>
  </div>
</div>
<div class="holder flipH">
  <div class="card">
    <div class="front">C</div>
    <div class="back">C</div>
  </div>
</div>

在 css3 2 中animation-delayanimation-iteration-count有这种类型的标签,你需要谷歌一下。

我想你想要这样的东西——

.holder {
  display:     inline-block;
  width:       64px;
  height:      64px;
  perspective: 700px;
}
.card, .front, .back{
  position:   absolute;
  height:     inherit;
  width:      inherit;
  transition: all .7s;
  transform-style:     preserve-3d;
  backface-visibility: hidden;
}
/* ::: FACES */
.front{background: tomato;}
.back{background:  slategray;}
/* ::: SETUP FACES */
.flipH .back{transform: rotateY(-180deg);}
.flipV .back{transform: rotateX(180deg);}
/* ::: HOVER EFFECTS (Remove Automated for this to work) */
.flipH:hover .card{ transform: rotateY(180deg); }
.flipV:hover .card{ transform: rotateX(-180deg); }
/* ::: AUTOMATED EFFECTS */
.flipH .card{
  animation: flipH 2s 0s 1 alternate ease-in-out;
  -webkit-animation: flipH 2s 0s infinite alternate ease-in-out;
}
.flipV .card{
  animation: flipV 2s 1s 1 alternate ease-in-out;
  -webkit-animation: flipV 2s 0s infinite alternate ease-in-out;
}
.flipH.flipH2 .card{
      animation: flipH 2s 2s 1 alternate ease-in-out;
  -webkit-animation: flipH 2s 0s infinite alternate ease-in-out;
}
@keyframes flipH {
  0% { transform: rotateY(0deg); }
  100% { transform: rotateY(-180deg); }
}
@-webkit-keyframes flipH {
  0% { transform: rotateY(0deg); }
  100% { transform: rotateY(-180deg); }
}
@keyframes flipV {
  0% { transform: rotateX(0deg); }
  100% { transform: rotateX(-180deg); }
}
@-webkit-keyframes flipV {
  0% { transform: rotateX(0deg); }
  100% { transform: rotateX(-180deg); }
}
<div class="holder flipH">
  <div class="card">
    <div class="front">A</div>
    <div class="back">A</div>
  </div>
</div>
<div class="holder flipV">
  <div class="card">
    <div class="front">B</div>
    <div class="back">B</div>
  </div>
</div>
<div class="holder flipH flipH2">
  <div class="card">
    <div class="front">C</div>
    <div class="back">C</div>
  </div>
</div>

我希望它能帮助你。

最新更新