有详情注释说明

<html>
<style>
  * {
    padding: 0;
    margin: 0;
  }

  body,
  html {
    height: 100%;
  }

  body {

    /*perspective 属性指定了观察者与z=0平面的距离,使具有三维位置变换的元素产生透视效果。z>0的三维元素比正常大,而z<0时则比正常小,
    大小程度由该属性的值决定。默认情况下,消失点位于元素的中心,但是可以通过设置perspective-origin属性来改变其位置。*/
    -webkit-perspective: 1000px;
    -moz-perspective: 1000px;
    -ms-perspective: 1000px;
    perspective: 1000px;
    background-color: #030303;
    font-family: '微软雅黑';
  }

  .book {
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -300px;
    width: 400px;
    height: 550px;
    background-color: #fff;
    -webkit-transform: rotateX(30deg);
    -ms-transform: rotateX(30deg);
    -o-transform: rotateX(30deg);
    transform: rotateX(30deg);
  }

  .preserve-3d {

    /*transform-style属性指定了,该元素的子元素是(看起来)位于三维空间内,
    还是在该元素所在的平面内被扁平化。*/
    -webkit-transform-style: preserve-3d;
    -moz-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    /*规定如何在 3D 空间中呈现被嵌套的元素*/
    transform-style: preserve-3d;
  }

  .book-page {
    position: absolute;
    top: 0;
    left: 0;
    width: 400px;
    height: 550px;
    /*设置四个边框的样式*/
    border: 1px solid papayawhip;
    text-align: center;
  }

  .book-page-box {
    -webkit-transform-origin: 0 50%;
    -moz-transform-origin: 0 50%;
    -ms-transform-origin: 0 50%;
    -o-transform-origin: 0 50%;
    /*设置旋转元素的基点位置*/
    transform-origin: 0 50%;
    -webkit-transform: rotateY(0deg);
    -ms-transform: rotateY(0deg);
    -o-transform: rotateY(0deg);
    /*旋转DIV元素*/
    transform: rotateY(0deg);
  }

  @keyframes flipBook1 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-160deg);
      -ms-transform: rotateY(-160deg);
      -o-transform: rotateY(-160deg);
      transform: rotateY(-160deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /* Firefox */
  @-moz-keyframes flipBook1 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-160deg);
      -ms-transform: rotateY(-160deg);
      -o-transform: rotateY(-160deg);
      transform: rotateY(-160deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /* Safari and Chrome */
  @-webkit-keyframes flipBook1 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-160deg);
      -ms-transform: rotateY(-160deg);
      -o-transform: rotateY(-160deg);
      transform: rotateY(-160deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /* Opera */
  @-o-keyframes flipBook1 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-160deg);
      -ms-transform: rotateY(-160deg);
      -o-transform: rotateY(-160deg);
      transform: rotateY(-160deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  @keyframes flipBook2 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-150deg);
      -ms-transform: rotateY(-150deg);
      -o-transform: rotateY(-150deg);
      transform: rotateY(-150deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /* Firefox */
  @-moz-keyframes flipBook2 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-150deg);
      -ms-transform: rotateY(-150deg);
      -o-transform: rotateY(-150deg);
      transform: rotateY(-150deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /* Safari and Chrome */
  @-webkit-keyframes flipBook2 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-150deg);
      -ms-transform: rotateY(-150deg);
      -o-transform: rotateY(-150deg);
      transform: rotateY(-150deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /* Opera */
  @-o-keyframes flipBook2 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-150deg);
      -ms-transform: rotateY(-150deg);
      -o-transform: rotateY(-150deg);
      transform: rotateY(-150deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  @keyframes flipBook3 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-140deg);
      -ms-transform: rotateY(-140deg);
      -o-transform: rotateY(-140deg);
      transform: rotateY(-140deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /* Firefox */
  @-moz-keyframes flipBook3 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-140deg);
      -ms-transform: rotateY(-140deg);
      -o-transform: rotateY(-140deg);
      transform: rotateY(-140deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /* Safari and Chrome */
  @-webkit-keyframes flipBook3 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-140deg);
      -ms-transform: rotateY(-140deg);
      -o-transform: rotateY(-140deg);
      transform: rotateY(-140deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /* Opera */
  @-o-keyframes flipBook3 {
    0% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }

    50% {
      -webkit-transform: rotateY(-140deg);
      -ms-transform: rotateY(-140deg);
      -o-transform: rotateY(-140deg);
      transform: rotateY(-140deg);
    }

    100% {
      -webkit-transform: rotateY(0deg);
      -ms-transform: rotateY(0deg);
      -o-transform: rotateY(0deg);
      transform: rotateY(0deg);
    }
  }

  /*书的封面*/
  .book-page-1 .page-front {
    background-color: cornflowerblue;
  }

  .book-page-1 .page-back {
    background-color: #fff;
  }

  .book-page-1 .page-front p {
    font-size: 40px;
    color: #fff;
    margin-top: 100px;
    font-family: 华文琥珀;
    vertical-align: middle;
    text-align: center;
  }

  .flip-animation-1 {
    /*把 "flipBook" 动画捆绑到 div 元素,时长:17 秒*/
    animation: flipBook1 17s;
    -moz-animation: flipBook1 17s;
    /* Firefox */
    -webkit-animation: flipBook1 17s;
    /* Safari and Chrome */
    -o-animation: flipBook1 17s;
    /* Opera */
  }

  /*书的第二页*/
  .book-page-2 .page-back,
  .book-page-2 .page-front {
    background-color: #fff;
  }

  .book-page-2 .page-front p {
    font-size: 25px;
    color: #1976D2;
    font-family: 华文楷体;
    margin-top: 100px;
    writing-mode: tb-rl;
  }

  .flip-animation-2 {
    /*把 "flipBook2" 动画捆绑到 div 元素,时长:13 秒,延长2秒*/
    animation: flipBook2 13s 2s;
    -moz-animation: flipBook2 13s 2s;
    /* Firefox */
    -webkit-animation: flipBook2 13s 2s;
    /* Safari and Chrome */
    -o-animation: flipBook2 13s 2s;
    /* Opera */
  }

  /*书的第三页*/
  .book-page-3 .page-back,
  .book-page-3 .page-front {
    background-color: #fff;
  }

  .book-page-3 .page-front p {
    font-size: 30px;
    color: #1976D2;
    margin-top: 100px;
    font-family: 华文楷体;
  }

  .flip-animation-3 {
    animation: flipBook3 10s 3s;
    -moz-animation: flipBook3 10s 3s;
    /* Firefox */
    -webkit-animation: flipBook3 10s 3s;
    /* Safari and Chrome */
    -o-animation: flipBook3 10s 3s;
    /* Opera */
  }

  /*书的第四页*/
  .book-page-4 .page-front p {
    font-size: 30px;
    color: #1976D2;
    margin-top: 50px;
    writing-mode: tb-rl;
    font-family: 华文楷体;
  }
</style>

<body>
  <!-- 书的主体 -->
  <div class="book preserve-3d">
    <!-- 书的最后一页 -->
    <div class="book-page-box book-page-4 preserve-3d">
      <div class="book-page page-front">
        <p>
          淫邪不能惑其心,愚智贤不肖,不惧于物,故合于道。

          所以能年皆度百岁而动作不衰者,以其德全不危也。
          <br />
          <br />
          <br />
        </p>
      </div>
    </div>
    <!-- 书的第三页 -->
    <div class="book-page-box book-page-3 preserve-3d flip-animation-3">
      <div class="book-page page-front">
        <p>
          不时御神,务快其心,逆于生乐,起居无节,故半百而衰也。
          夫上古圣人之教下也,皆谓之虚邪贼风,避之有时,恬惔虚无,真气从之,精神内守,病安从来。

          是以志闲而少欲,心安而不惧,形劳而不倦,气从以顺,各从其欲,皆得所愿。

          故美其食,任其服,乐其俗,高下不相慕,其民故曰朴。

          是以嗜欲不能劳其目,
        </p>
      </div>
    </div>
    <!-- 书的第二页 -->
    <div class="book-page-box book-page-2 preserve-3d flip-animation-2">
      <div class="book-page page-front">
        <p>
          昔在黄帝,生而神灵,弱而能言,幼而徇齐,长而敦敏,成而登天。
          岐伯对曰:上古之人,其知道者,法于阴阳,和于术数,食饮有节,起居有常,不妄作劳,故能形与神俱,而尽终其天年,度百岁乃去。
          今时之人不然也,以酒为浆,以妄为常,醉以入房,以欲竭其精,以耗散其真,不知持满,
        </p>
      </div>
    </div>
    <!-- 书的封面 -->
    <div class="book-page-box book-page-1 preserve-3d flip-animation-1">
      <div class="book-page page-front">
        <p>
          <br />
          <br />
          <br />
          <br />
          黄帝内经
        </p>
      </div>
    </div>
  </div>
</body>

</html>

 

更多推荐

HTML CSS实现翻页效果(动画)