前端书籍翻页效果

目录

前端书籍翻页效果

前端实现翻书效果,附带vue源码
源码下载地址

前言

实际业务开发中,有时候会遇到需要在前端页面内实现翻书效果的需求,本篇文章就为大家介绍如何使用vue实现前端翻书效果,包括鼠标拖动/点击实现翻页,通过按钮实现翻页等功能,下面给出核心代码示例。完整代码请移步之下载页面下载

代码示例

创建模板页面

创建13个页面,每个页面是一张图片,所有图片资源统一放置在源码包内。

html 复制代码
<template>
<!--  创建id为book的书籍容器,内部包含13个页面-->
  <div id="book">
    <div><img src="./assets/img/00.jpg" alt=""></div>
    <div><img src="./assets/img/11.jpg" alt=""></div>
    <div><img src="./assets/img/12.jpg" alt=""></div>
    <div><img src="./assets/img/21.jpg" alt=""></div>
    <div><img src="./assets/img/22.jpg" alt=""></div>
    <div><img src="./assets/img/31.jpg" alt=""></div>
    <div><img src="./assets/img/32.jpg" alt=""></div>
    <div><img src="./assets/img/41.jpg" alt=""></div>
    <div><img src="./assets/img/42.jpg" alt=""></div>
    <div><img src="./assets/img/51.jpg" alt=""></div>
    <div><img src="./assets/img/52.jpg" alt=""></div>
    <div><img src="./assets/img/61.jpg" alt=""></div>
    <div><img src="./assets/img/62.jpg" alt=""></div>
  </div>
</template>

css样式

css 复制代码
html,body, #app{
  width: 100%;
  height: 100%;
  overflow: hidden;
  padding: 30px;
}

#app {
  margin: 0 auto;
  padding: 2rem;
  font-weight: normal;
}

编写js代码

初始化翻书节点,包含配置项字段,如书籍宽高、位置等字段,还可以监听翻书事件,比如当前书籍翻到第几页、正在翻页、翻页结束等事件

js 复制代码
$("#book").turn({
    width: 1280,
    height: 720,
    // 自动居中
    autoCenter: true,
    // 翻页速度,默认600ms
    duration: 1000,
    // 展示方式,single:单页展示,double:双页展示
    display: "double",
    // 开启硬件加速
    acceleration: true,
    when: {
      start: function (e, page, view) {
        // 开始翻页时
      },
      turning: function (e, page, view) {
        // 正在翻页
      },
      turned: function (e, page, view) {
        // 翻页完成
        console.log(e); // 事件对象
        console.log(page); // 翻到第几页 4
        console.log(view); //当前展示那几页 是一个数组 [4,5]
      }
    }
  });

通过按钮实现上一页下一页

js 复制代码
	// 通过点击事件实现书籍的翻页功能
	$("#prev").click(function () {
	  // 上一页
	  $("#book").turn("previous");
	})
	$("#next").click(function () {
	  // 下一页
	  $("#book").turn("next");
	})

结论

通过上述简单的几行代码,就可以轻松实现翻书效果,除此之后页面内容还可以使用vue组件,这里不再赘述。

大家有任何问题都可评论区留言或私信,相互交流学习!😉😉😉

相关推荐
霪霖笙箫7 分钟前
「JS全栈AI Agent学习」六、当AI遇到矛盾,该自己决定还是问你?—— Human-in-the-Loop
前端·面试·agent
煜bart8 分钟前
使用 TypeScript 实现算法处理
开发语言·前端·javascript
Mike_jia21 分钟前
NginxPulse:Nginx日志监控革命!实时洞察Web流量与安全态势的智能利器
前端
风之舞_yjf26 分钟前
Vue基础(31)_插件(plugins)、scoped样式
前端·vue.js
M ? A34 分钟前
Vue3+TS实战避坑指南
前端·vue.js·经验分享
Mintopia40 分钟前
你以为是技术问题,其实是流程问题:工程效率的真相
前端
Mintopia1 小时前
一套能落地的"防 Bug"习惯:不用加班也能少出错
前端
亿元程序员1 小时前
箭头游戏那么火,搞个3D的可以吗?我:这不是3年前的游戏了吗?
前端
IT_陈寒1 小时前
SpringBoot里的这个坑差点让我加班到天亮
前端·人工智能·后端
巫山老妖1 小时前
大模型工程三驾马车:Prompt Engineering、Context Engineering 与 Harness Engineering 深度解析
前端