当前位置: 首页 > ops >正文

【前端分享】CSS实现3种翻页效果类型,附源码!

 

使用 css 可以实现多种翻页效果,比如书本翻页、卡片翻转等。以下是两种常见的翻页效果实现:

效果 1:书本翻页效果

通过 transform 和 rotateY 实现 3D 翻页效果。

html 结构
<divclass="book">
<divclass="page page1">第一页</div>
<divclass="page page2">第二页</div>
</div>
CSS 样式
body {
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
margin: 0;
background-color: #f0f0f0;
perspective: 1000px; /* 3D 透视效果 */
}.book {
width: 200px;
height: 300px;
position: relative;
transform-style: preserve-3d; /* 保持 3D 效果 */
}.page {
position: absolute;
width: 100%;
height: 100%;
background-color: white;
border: 1px solid #ccc;
box-shadow: 04px8pxrgba(0, 0, 0, 0.2);
display: flex;
justify-content: center;
align-items: center;
font-size: 20px;
backface-visibility: hidden; /* 隐藏背面 */
transition: transform 1s ease-in-out;
}.page1 {
transform-origin: left;
}.page2 {
transform-origin: right;
transform: rotateY(180deg); /* 初始状态为背面 */
}.book:hover.page1 {
transform: rotateY(-180deg); /* 翻页效果 */
}.book:hover.page2 {
transform: rotateY(0deg); /* 翻页效果 */
}

效果 2:卡片翻转效果

通过 transform 和 rotateY 实现卡片翻转效果。

HTML 结构
<divclass="card">
<divclass="card-front">正面</div>
<divclass="card-back">背面</div>
</div>
CSS 样式
body {
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
margin: 0;
background-color: #f0f0f0;
perspective: 1000px; /* 3D 透视效果 */
}.card {
width: 200px;
height: 300px;
position: relative;
transform-style: preserve-3d; /* 保持 3D 效果 */
transition: transform 1s ease-in-out;
}.card-front,
.card-back {
position: absolute;
width: 100%;
height: 100%;
background-color: white;
border: 1px solid #ccc;
box-shadow: 04px8pxrgba(0, 0, 0, 0.2);
display: flex;
justify-content: center;
align-items: center;
font-size: 20px;
backface-visibility: hidden; /* 隐藏背面 */
}.card-front {
background-color: #ffcc00;
}.card-back {
background-color: #00ccff;
transform: rotateY(180deg); /* 初始状态为背面 */
}.card:hover {
transform: rotateY(180deg); /* 翻转效果 */
}

效果 3:多页翻页效果

通过多个页面叠加实现多页翻页效果。

HTML 结构
<divclass="flip-book">
<divclass="page page1">第一页</div>
<divclass="page page2">第二页</div>
<divclass="page page3">第三页</div>
</div>
CSS 样式
body {
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
margin: 0;
background-color: #f0f0f0;
perspective: 1000px; /* 3D 透视效果 */
}.flip-book {
width: 200px;
height: 300px;
position: relative;
transform-style: preserve-3d; /* 保持 3D 效果 */
}.page {
position: absolute;
width: 100%;
height: 100%;
background-color: white;
border: 1px solid #ccc;
box-shadow: 04px8pxrgba(0, 0, 0, 0.2);
display: flex;
justify-content: center;
align-items: center;
font-size: 20px;
backface-visibility: hidden; /* 隐藏背面 */
transition: transform 1s ease-in-out;
}.page1 {
transform-origin: left;
}.page2 {
transform-origin: left;
transform: rotateY(-180deg); /* 初始状态为背面 */
}.page3 {
transform-origin: left;
transform: rotateY(-180deg); /* 初始状态为背面 */
}.flip-book:hover.page1 {
transform: rotateY(-180deg); /* 翻页效果 */
}.flip-book:hover.page2 {
transform: rotateY(0deg); /* 翻页效果 */
}.flip-book:hover.page3 {
transform: rotateY(0deg); /* 翻页效果 */
}

总结

  • 书本翻页效果:通过 rotateY 和 transform-origin 实现。

  • 卡片翻转效果:通过 rotateY 和 backface-visibility 实现。

  • 多页翻页效果:通过多个页面叠加和 rotateY 实现。

这些效果可以用于网页中的交互设计,比如展示图片、卡片或书籍内容。根据需求选择合适的翻页效果!

·······END·······

  喜欢的话可以点个赞关注博主哦!!! 

http://www.xdnf.cn/news/4740.html

相关文章:

  • 解决Ceph 14.2.22 Nautilus版本监视器慢操作问题的实践指南
  • 【Touching China】2012-2016
  • 从 CFD 到 DEM:积鼎流体仿真技术拓展与协同互补之路
  • 破解老龄化困局:国家政策扶持与智慧养老实践路径
  • 关于form、自定义Hook、灰度发布、正则表达(只能输入数字和不要空格)
  • 笔试专题(十六)
  • Java线程安全问题深度解析与解决方案
  • <template>标签的用法
  • QT QList容器及行高亮
  • Django进阶:用户认证、REST API与Celery异步任务全解析
  • 搭建以太坊私有链完整指南:从零实现数据存储API
  • 2025年3月青少年机器人技术等级考试(二级)实际操作真题试卷
  • 如何在vite构建的vue项目中从0到1配置postcss-pxtorem
  • 02-GBase 8s 事务型数据库 客户端工具dbaccess
  • 什么是变量提升?
  • WiFi出现感叹号上不了网怎么办 轻松恢复网络
  • Off-Policy策略演员评论家算法SAC详解:python从零实现
  • SpringBoot使用定时线程池ScheduledThreadPoolExecutor
  • 【C++游戏引擎开发】第34篇:C++实现反射
  • 【嵌入式开发-LCD】
  • 【平面波导外腔激光器专题系列】1064nm单纵模平面波导外腔激光器‌
  • C++继承语法讲解
  • 2025最新:3分钟使用Docker快速部署Redis集群
  • 为什么 MySQL 用 B+ 树作为数据的索引,以及在 InnoDB 中数据库如何通过 B+ 树索引来存储数据以及查找数据
  • base64与图片的转换和预览(高阶玩法)
  • 【Ubuntu系统镜像文件下载(官网)】
  • AI赋能高频PCB信号完整性优化
  • 正态分布和幂律分布
  • 存储器:DDR和HBM的区别
  • css样式基础