滚动翻页效果

效果:
在这里插入图片描述

代码:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      html {
        text-align: center;
      }
      .container {
        position: relative;
        width: 300px;
        height: 130px;
        margin: 50px auto;
        background-color: pink;
        overflow: hidden;
      }
      .book-parent {
        position: absolute;
      }
      .book {
        animation: book 0.2s ease-in;
      }
      .bookClone {
        animation: bookClone 0.2s ease-in;
      }
      .bookReverse {
        animation: bookReverse 0.2s ease-in;
      }
      .bookCloneReverse {
        animation: bookCloneReverse 0.2s ease-in;
      }
      @keyframes book {
        from {
          transform: translate(300px);
          opacity: 0;
        }
        to {
          transform: translate(0);
          opacity: 1;
        }
      }
      @keyframes bookClone {
        from {
          transform: translate(0);
          opacity: 1;
        }
        to {
          transform: translate(-300px);
          opacity: 0;
        }
      }
      @keyframes bookReverse {
        from {
          transform: translate(-300px);
        }
        to {
          transform: translate(0);
        }
      }
      @keyframes bookCloneReverse {
        from {
          transform: translate(0);
        }
        to {
          transform: translate(300px);
        }
      }
    </style>
  </head>
  <body>
    <h1>滕王阁序</h1>
    <div id="container" class="container">
      <div id="book-parent" class="book-parent"></div>
    </div>
    <button id="prev">上一页</button>
    <button id="next">下一页</button>
  </body>

  <script>
    let str = `豫章故郡,洪都新府。星分翼轸,地接衡庐。襟三江而带五湖,控蛮荆而引瓯越。物华天宝,龙光射牛斗之墟;人杰地灵,徐孺下陈蕃之榻。雄州雾列,俊采星驰。台隍枕夷夏之交,宾主尽东南之美。都督阎公之雅望,棨戟遥临;宇文新州之懿范,襜帷暂驻。十旬休假,胜友如云;千里逢迎,高朋满座。腾蛟起凤,孟学士之词宗;紫电青霜,王将军之武库。家君作宰,路出名区;童子何知,躬逢胜饯。

时维九月,序属三秋。潦水尽而寒潭清,烟光凝而暮山紫。俨骖騑于上路,访风景于崇阿;临帝子之长洲,得天人之旧馆。层峦耸翠,上出重霄;飞阁流丹,下临无地。鹤汀凫渚,穷岛屿之萦回;桂殿兰宫,即冈峦之体势。

披绣闼,俯雕甍,山原旷其盈视,川泽纡其骇瞩。闾阎扑地,钟鸣鼎食之家;舸舰弥津,青雀黄龙之舳。云销雨霁,彩彻区明。落霞与孤鹜齐飞,秋水共长天一色。渔舟唱晚,响穷彭蠡之滨;雁阵惊寒,声断衡阳之浦。

遥襟甫畅,逸兴遄飞。爽籁发而清风生,纤歌凝而白云遏。睢园绿竹,气凌彭泽之樽;邺水朱华,光照临川之笔。四美具,二难并。穷睇眄于中天,极娱游于暇日。天高地迥,觉宇宙之无穷;兴尽悲来,识盈虚之有数。望长安于日下,目吴会于云间。地势极而南溟深,天柱高而北辰远。关山难越,谁悲失路之人?萍水相逢,尽是他乡之客。怀帝阍而不见,奉宣室以何年?

嗟乎!时运不齐,命途多舛。冯唐易老,李广难封。屈贾谊于长沙,非无圣主;窜梁鸿于海曲,岂乏明时?所赖君子见机,达人知命。老当益壮,宁移白首之心?穷且益坚,不坠青云之志。酌贪泉而觉爽,处涸辙以犹欢。北海虽赊,扶摇可接;东隅已逝,桑榆非晚。孟尝高洁,空余报国之情;阮籍猖狂,岂效穷途之哭!

勃,三尺微命,一介书生。无路请缨,等终军之弱冠;有怀投笔,慕宗悫之长风。舍簪笏于百龄,奉晨昏于万里。非谢家之宝树,接孟氏之芳邻。他日趋庭,叨陪鲤对;今兹捧袂,喜托龙门。杨意不逢,抚凌云而自惜;钟期既遇,奏流水以何惭?

呜乎!胜地不常,盛筵难再;兰亭已矣,梓泽丘墟。临别赠言,幸承恩于伟饯;登高作赋,是所望于群公。敢竭鄙怀,恭疏短引;一言均赋,四韵俱成。请洒潘江,各倾陆海云尔:

滕王高阁临江渚,佩玉鸣鸾罢歌舞。

画栋朝飞南浦云,珠帘暮卷西山雨。

闲云潭影日悠悠,物换星移几度秋。

阁中帝子今何在?槛外长江空自流。`;

    let index = 0;
    const book = document.querySelector("#book-parent");
    const container = document.querySelector("#container");
    const maxIndex = ~~(str.length / 70);
    book.innerText = str.substring(index * 70, (index + 1) * 70);
    let bookClone = null;
    //上一页
    document.querySelector("#prev").addEventListener("click", () => {
      if (book.classList.contains("bookReverse") || index === 0) return;
      bookClone = book.cloneNode(true);
      container.appendChild(bookClone);
      index--;
      book.innerText = str.substring(index * 70, (index + 1) * 70);

      book.classList.add("bookReverse");
      bookClone.classList.add("bookCloneReverse");
    });
    //下一页
    document.querySelector("#next").addEventListener("click", () => {
      if (book.classList.contains("book") || index === maxIndex) return;
      bookClone = book.cloneNode(true);
      container.appendChild(bookClone);
      index++;
      book.innerText = str.substring(index * 70, (index + 1) * 70);

      book.classList.add("book");
      bookClone.classList.add("bookClone");
    });
    //监听动画结束
    book.addEventListener("animationend", () => {
      book.classList.remove("book");
      book.classList.remove("bookReverse");
      container.removeChild(bookClone);
    });
  </script>
</html>

  • 10
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值