微信小程序 |从零实现酷炫纸质翻页效果

简介: 微信小程序 |从零实现酷炫纸质翻页效果

一、效果展示

image.gif


二、需求背景

  • 在传统的·电子书应用中,我们体验往往是非常生硬。每个页面之间的切换仅仅是简单的切入切出,没有任何的生动感。这使得我们在看电子书的同时仍然会觉得,我们真的只是在玩手机,除了简单的文字输入没有任何美和动效的享受!
  • 在传统的相册应用中,我们也是是简单的左右划入划出,也显得略微生硬。

于是,就有了今天所分享的类纸感的翻页动画,在手机上实现物理纸质书或者纸质相册的翻页效果,大幅度提升用户观感度!


三、实现代码

3.1 核心事件的监听

对于鼠标点击然后拖动时纸张的动画会随着鼠标的位置进行移动,所以我们需要实时去监听鼠标点击进入和点击离开的事件,这样就可以明确地给动画元素传达开始和结束的指令。

  • 使用@引入相应的鼠标事件
<view id='magazine'
      v-on:swipeleft="touchl" v-on:swiperight="touchr" 
      @mousedown="pcmousedown" @mouseup="pcmouseup"
    >
    <slot></slot>
</view>


  • 定义相应的鼠标事件的动作内容
pcmousedown(event) {
        this.mDown = event.clientX;
      },
      pcmouseup(event) {
      this.mUp = event.clientX;
      if ((this.mDown - this.mUp) > 70) {
        touchLeft('#magazine');
      }
      if ((this.mUp - this.mDown) > 70) {
          touchRight('#magazine');
      }
}


3.2 使用Slot插槽技术为内容预留空位

为了实现在页面中可以放入自己的页面内容时,我们在定义页面模板的时候需要使用<slot>标签对后续的内容进行留白操作!

  • 如果我们要放置的内容比较单一的时候,我们可以直接使用匿名slot

(1) 匿名slot—子组件

<div class="child">
    <h1>子组件</h1>
    <slot>这是个匿名插槽(没有name属性),这串字符是匿名插槽的默认值。</slot>
</div>


(2)匿名slot — 父组件

<div class="parent">
 <h1>父组件</h1>
 <child>
     <p>我是其他内容!!!!!</p>
 </child>
 </div>


(3)效果

父组件
子组件
我是其他内容!!!!! (匿名插槽的默认值被覆盖)


  • 若我们想要在页面中所放的内容较多且有多个模块的时候,我们这个时候可以使用命名slot
    (1) 命名slot—子组件
<div class="child">
    <h1>子组件</h1>
      <slot name="body">主体默认值</slot>
</div>


(2)命名slot — 父组件

<div class="parent">
 <h1>父组件</h1>
 <child>
     <p slot="body">我是主体</p>
 </child>
 </div>


(3)效果

父组件
子组件
我是主体 (具名插槽<slot name="body">的默认值被覆盖)


3.3 引入CSS动画实现纸张折叠效果

为了使动画效果更好的控制,我们首先要定位到相应的元素,所以这里我们需要引入JQuery,然后我们将动画通过js代码的形式进行控制。

(1)向左翻页控制函数

export const touchLeft = function (magazineId){
  var pageCount = $(magazineId).turn("pages"); //total page
  var currentPage = $(magazineId).turn("page"); //now page
  if (currentPage >= pageCount) {
    return;
  }
  if (currentPage <= pageCount) {
    $(magazineId).turn('page', currentPage + 1);
  }
}


(2)向右翻页控制函数

export const touchRight = function (magazineId){
  var pageCount = $(magazineId).turn("pages"); 
  var currentPage = $(magazineId).turn("page");
  if (currentPage <= pageCount) {
    if (currentPage <= 1) {
      return;
    }
    $(magazineId).turn('page', currentPage - 1);
  }
}


四、源码下载

相关文章
|
小程序
微信小程序:免费翻页时钟和todolist
微信小程序:免费翻页时钟和todolist
微信小程序:免费翻页时钟和todolist
|
开发者 索引
如何在微信小游戏制作工具中实现关卡翻页功能?
如何在微信小游戏制作工具中实现关卡翻页功能?
439 0
|
自然语言处理 搜索推荐 小程序
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。
|
9月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
小程序 前端开发 Android开发
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
2398 29
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
|
10月前
|
小程序 JavaScript API
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
这篇文章介绍了使用uni-halo框架进行微信小程序开发的过程,包括选择该框架的原因、开发目标以及项目配置和部署的步骤。
518 0
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
4267 7
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
4936 1
|
人工智能 开发框架 机器人
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
AstrBot 是一个开源的多平台聊天机器人及开发框架,支持多种大语言模型和消息平台,具备多轮对话、语音转文字等功能。
8977 38
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
|
人工智能 自然语言处理 小程序
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
3982 11
技术小白如何利用DeepSeek半小时开发微信小程序?