简单几步用纯CSS3实现3D翻转效果


Posted in HTML / CSS onJanuary 17, 2019

作为前端开发人员的必修课,CSS3能带我们完成许多基本动效,本期我们将用CSS3实现hover翻转效果~

第一步非常简单,我们简单画1个演示方块,为其 添加transition和transform属性

// 本示例均使用Sass语法
.block {
  width: 200px;
  height: 200px;
  background: brown;
  cursor: pointer;
  transition: 0.8s;
  &:hover {
    transform: rotateY(180deg);
  }
}

我们看一看这时候的效果:

简单几步用纯CSS3实现3D翻转效果

这里 需要注意 的是: transition属性要写在.block上而不是hover上 ,如果只在hover上写transition,则鼠标移出时并没有transition的过渡效果,如果我们只将transition写在hover上:

简单几步用纯CSS3实现3D翻转效果

第二步比较关键:我们不难发现始终在1个平面上翻转,不够有立体感,因此我们需要稍加改变思路—— 用2层div嵌套

// html部分
<div class="block">
    <div class="block-in"></div>
</div>
// CSS部分
.block {
  width: 200px;
  height: 200px;
  cursor: pointer;
 
  &-in {
    background: brown;
    height: 100%;
    transition: 0.8s;
  }
  
  &:hover .block-in {
    transform: rotateY(180deg);
  }
}

此时效果没变,如下:

简单几步用纯CSS3实现3D翻转效果

这个时候 关键的1步 来了:我们需要 给外层添加perspective和transform-style属性 ,为整个动画增添3D变形效果:

.block {
  width: 200px;
  height: 200px;
  cursor: pointer;
  /* 3D变形 */
  transform-style: preserve-3d;
  -webkit-perspective: 1000;
  -moz-perspective: 1000;
  -ms-perspective: 1000;
  perspective: 1000;
 
  &-in {
    background: brown;
    height: 100%;
    transition: 0.8s;
  }
 
  &:hover .block-in {
    transform: rotateY(180deg);
  }
}

最终实现效果如下:

简单几步用纯CSS3实现3D翻转效果

最终我们 总结一下思路

1.建立内外2层div,鼠标 hover 到外层时,内层div添加翻转 transform: rotateY(180deg)

2.注意将 transition 属性添加到需要翻转的div上,而不是 hover 时

3.外层div添加 perspective 和 transform-style 属性,最终实现3D翻转效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS实现的一闪而过的图片闪光效果
Apr 23 HTML / CSS
使用 CSS3 中@media 实现网页自适应的示例代码
Mar 24 HTML / CSS
html5+css3之制作header实例与更新
Dec 21 HTML / CSS
基于HTML5的WebSocket的实例代码
Aug 15 HTML / CSS
详解Html5微信支付爬坑之路
Jul 24 HTML / CSS
canvas基础之图形验证码的示例
Jan 02 HTML / CSS
HTML5 Canvas自定义圆角矩形与虚线示例代码
Aug 02 HTML / CSS
html5开发之viewport使用
Oct 17 HTML / CSS
HTML5拖放API实现拖放排序的实例代码
May 11 HTML / CSS
html5 http的轮询和Websocket原理
Oct 19 HTML / CSS
深入了解canvas在移动端绘制模糊的问题解决
Apr 30 HTML / CSS
HTML5简单实现添加背景音乐的几种方法
May 12 HTML / CSS
css3实现3D文本悬停改变效果的示例代码
Jan 16 #HTML / CSS
css3实现元素环绕中心点布局的方法示例
Jan 15 #HTML / CSS
CSS3改变浏览器滚动条样式
Jan 04 #HTML / CSS
浅谈CSS3 动画卡顿解决方案
Jan 02 #HTML / CSS
纯CSS3实现漂亮的input输入框动画样式库(Text input love)
Dec 29 #HTML / CSS
10分钟入门CSS3 Animation
Dec 25 #HTML / CSS
10分钟理解CSS3 Grid布局
Dec 20 #HTML / CSS
You might like
PHP 文件系统详解
2012/09/13 PHP
判断php数组是否为索引数组的实现方法
2013/06/13 PHP
PHP curl 获取响应的状态码的方法
2014/01/13 PHP
Thinkphp和Bootstrap结合打造个性的分页样式(推荐)
2016/08/01 PHP
Yii框架日志记录Logging操作示例
2018/07/12 PHP
laravel 实现关闭CSRF(全部关闭、部分关闭)
2019/10/21 PHP
laravel7学习之无限级分类的最新实现方法
2020/09/30 PHP
关于恒等于(===)和非恒等于(!==)
2007/08/20 Javascript
Extjs学习笔记之五 一个小细节renderTo和applyTo的区别
2010/01/07 Javascript
25个优雅的jQuery Tooltip插件推荐
2011/05/25 Javascript
JavaScript高级程序设计 读书笔记之八 Function类及闭包
2012/02/27 Javascript
JavaScript版TAB选项卡效果实例
2013/08/16 Javascript
图标线性回归斜着移动到指定的位置
2013/08/16 Javascript
jQuery滚动条插件nanoscroller使用指南
2015/04/21 Javascript
jQuery制作网页版选项卡
2016/07/28 Javascript
React-Router如何进行页面权限管理的方法
2017/12/06 Javascript
Node.js 利用cheerio制作简单的网页爬虫示例
2018/03/01 Javascript
使用vuex缓存数据并优化自己的vuex-cache
2018/05/30 Javascript
详解基于 Node.js 的轻量级云函数功能实现
2019/07/08 Javascript
[52:02]DOTA2-DPC中国联赛 正赛 Phoenix vs Dragon BO3 第二场 2月26日
2021/03/11 DOTA
python实现图片变亮或者变暗的方法
2015/06/01 Python
python实现学生信息管理系统
2020/04/05 Python
Python3实现的简单验证码识别功能示例
2018/05/02 Python
OpenCV2从摄像头获取帧并写入视频文件的方法
2018/08/03 Python
Python实现拷贝/删除文件夹的方法详解
2018/08/29 Python
Python实现随机创建电话号码的方法示例
2018/12/07 Python
PyQt5实现让QScrollArea支持鼠标拖动的操作方法
2019/06/19 Python
python实现ip地址的包含关系判断
2020/02/07 Python
HTML5本地存储之Web Storage应用介绍
2013/01/06 HTML / CSS
HTML5+CSS3实现拖放(Drag and Drop)示例
2014/07/07 HTML / CSS
加拿大最大的五金、家居装修和园艺产品商店:RONA
2017/01/27 全球购物
自我鉴定注意事项
2014/01/19 职场文书
2014年学生会干事工作总结
2014/11/07 职场文书
领导离职感言
2015/08/03 职场文书
python小程序之飘落的银杏
2021/04/17 Python
Javascript设计模式之原型模式详细
2021/10/05 Javascript