css3实现动画的三种方式


Posted in HTML / CSS onAugust 24, 2020

这是一个考验面试者对css的基础知识。

css 实现动画主要有3种方式

第一种是: transition 实现渐变动画

第二种是: transform 转变动画

第三种是: animation 实现自定义动画

下面具体讲一下3种动画的实现方式。

transition渐变动画

我们先看一下 transition 的属性:

  • property:填写需要变化的css属性如:width,line-height,font-size,color等,所有作用与dom样式的属性;
  • duration:完成过渡效果需要的时间单位(s或者ms)
  • timing-function:完成效果的速度曲线(linear,ease,ease-in,ease-out等等)
     

timing-function具体的值可以看下面的表格:

描述
linear 匀速(等于 cubic-bezier(0,0,1,1))
ease 从慢到快再到慢(cubic-bezier(0.25,0.1,0.25,1))
ease-in 慢慢变快(等于 cubic-bezier(0.42,0,1,1))
ease-out 慢慢变慢(等于 cubic-bezier(0,0,0.58,1))
ease-in-out 先变快再到慢(等于 cubic-bezier(0.42,0,0.58,1)),渐显渐隐效果
cubic-bezier( n , n , n , n ) 在 cubic-bezier 函数中定义自己的值。可能的值是 0 至 1 之间的数值
  • delay: 动画效果的延迟触发时间(单位ms或者s)

下面我们看一个完整的例子:

<div class="base"></div>
.base {
            width: 100px;
            height: 100px;
            display: inline-block;
            background-color: #0EA9FF;
            border-width: 5px;
            border-style: solid;
            border-color: #5daf34;
            transition-property: width,height,background-color,border-width;
            transition-duration: 2s;
            transition-timing-function: ease-in;
            transition-delay: 500ms;
        /*简写*/
        /*transition: all 2s ease-in 500ms;*/
            &:hover {
                width: 200px;
                height: 200px;
                background-color: #5daf34;
                border-width: 10px;
                border-color: #3a8ee6;
            }
        }

运行效果:

css3实现动画的三种方式

可以看到,鼠标移上去的时候,动画延迟0.5s开始,并且由于 border-color 没有设置到 transition-property 里面,所以是没有渐变动画的。

transform转变动画

transform属性应用于2D 或 3D转换。该属性允许我们能够对元素进行旋转、缩放、倾斜、移动这四类操作.一般是配合transition的属性一起使用。

  1. none:定义不进行任何转换,一般用于注册掉该转换。
  2. transform-functions:定义要进行转换的类型函数。主要有:

2.1 旋转(rotate):主要分为2D旋转和3D旋转。rotate(angle),2D 旋转,参数为角度,如45deg;rotate(x,y,z,angle),3D旋转,围绕原地到(x,y,z)的直线进行3D旋转;rotateX(angle),沿着X轴进行3D旋转;rotateY(angle);rotateZ(angle);

2.2 缩放(scale):一般用于元素的大小收缩设定。主要类型同上,有scale(x, y)、scale3d(x, y, z)、scaleX(x)、scaleY(y)、scaleZ(z),其中x、y、z为收缩比例。

2.3 倾斜(skew):主要用于对元素的样式倾斜。skew(x-angle, y-angle),沿着x和y轴的2D倾斜转换;skewX(angle),沿着x轴的2D倾斜转换;skew(angle),沿着y轴的2D倾斜转换。

2.4 移动(translate):主要用于将元素移动。translate(x, y),定义向x和y轴移动的像素点;translate(x, y, z),定义像x、y、z轴移动的像素点;translateX(x);translateY(y);translateZ(z)。

<h5>transition配合transform一起使用</h5>
<div class="base base2"></div>
.base2{
          transform:none;
          transition-property: transform;
          &:hover {
              transform:scale(0.8, 1.5) rotate(35deg) skew(5deg) translate(15px, 25px);
          }
      }

运行效果:

css3实现动画的三种方式

可以看到盒子发生了旋转,倾斜,平移,放大。

animation自定义动画

为了实现更灵活的动画效果,css3还提供了自定义动画的功能。

(1) name:需要绑定到选择器的keyframe名称。

(2) duration:完成该动画需要花费的时间,秒或毫秒。

(3) timing-function:跟transition-linear一样。

(4) delay:设置动画在开始之前的延迟。

(5) iteration-count:设置动画执行的次数,infinite为无限次循环。

(6) direction:是否轮询反向播放动画。normal,默认值,动画应该正常播放;alternate,动画应该轮流反向播放。

<h5 class="title">animate自定义动画</h5>
<div class="base base3"></div>
.base3 {
          border-radius: 50%;
          transform:none;
          position: relative;
          width: 100px;
          height: 100px;
          background: linear-gradient(
                  35deg,
                  #ccffff,
                  #ffcccc
          );
          &:hover {
              animation-name: bounce;
              animation-duration: 3s;
              animation-iteration-count: infinite;
          }
      }
      @keyframes bounce{
          0% {
              top: 0px;
          }
          50% {
              top: 249px;
              width: 130px;
              height: 70px;
          }
          100% {
              top: 0px;
          }
      }

运行效果:

css3实现动画的三种方式

可以看到,自定义动画能实现更灵活的动画效果,包括了第一种和第二种动画的所有功能,而且属性也更全面。

以上代码可以在线体验:地址

源码地址

以上就是css3实现动画的三种方式的详细内容,更多关于css3实现动画的资料请关注三水点靠木其它相关文章!

HTML / CSS 相关文章推荐
css3弹性盒模型实例介绍
May 27 HTML / CSS
简单介绍CSS3中Media Query的使用
Jul 07 HTML / CSS
使用CSS3来实现滚动视差效果的教程
Aug 24 HTML / CSS
几个解决兼容IE6\7\8不支持html5标签的几个方法
Jan 07 HTML / CSS
HTML5之SVG 2D入门6—视窗坐标系与用户坐标系及变换概述
Jan 30 HTML / CSS
HTML5拖拽文件到浏览器并实现文件上传下载功能代码
Jun 06 HTML / CSS
html5 利用canvas实现超级玛丽简单动画
Sep 06 HTML / CSS
HTML5+CSS3绘制锯齿状的矩形
Mar 01 HTML / CSS
详解HTML5中表单验证的8种方法介绍
Dec 19 HTML / CSS
amazeui树节点自动展开折叠面板并选中第一个树节点的实现
Aug 24 HTML / CSS
AmazeUI 等分网格的实现示例
Aug 25 HTML / CSS
css布局巧妙技巧之css三角示例的运用
Mar 16 HTML / CSS
使用CSS3实现字体颜色渐变的实现
Aug 10 #HTML / CSS
CSS3实现线性渐变用法示例代码详解
Aug 07 #HTML / CSS
CSS3 input框的实现代码类似Google登录的动画效果
Aug 04 #HTML / CSS
纯CSS3+DIV实现小三角形边框效果的示例代码
Aug 03 #HTML / CSS
纯CSS3实现鼠标滑过按钮动画第二节
Jul 16 #HTML / CSS
css3实现小箭头各种图形效果
Jul 08 #HTML / CSS
基于CSS3的animation属性实现微信拍一拍动画效果
Jun 22 #HTML / CSS
You might like
77A一级收信机修理记
2021/03/02 无线电
PHP中include与require使用方法区别详解
2013/10/19 PHP
在PHP上显示JFreechart画的统计图方法
2013/11/03 PHP
laravel框架之数据库查出来的对象实现转化为数组
2019/10/23 PHP
javascript学习之闭包分析
2010/12/02 Javascript
JQuery实现简单验证码提示解决方案
2012/12/20 Javascript
Jquery+CSS3实现一款简洁大气带滑动效果的弹出层
2013/05/15 Javascript
js控制表单操作的常用代码小结
2013/08/15 Javascript
jQuery实现仿淘宝带有指示条的图片转动切换效果完整实例
2015/03/04 Javascript
jQuery实现在列表的首行添加数据
2015/05/19 Javascript
javascript给span标签赋值的方法
2015/11/26 Javascript
JavaScript重载函数实例剖析
2016/05/13 Javascript
URL的参数中有加号传值变为空格的问题(URL特殊字符)
2016/11/04 Javascript
bootstrap datetimepicker实现秒钟选择下拉框
2017/01/05 Javascript
Three.js获取鼠标点击的三维坐标示例代码
2017/03/24 Javascript
nodejs遍历文件夹下并操作HTML/CSS/JS/PNG/JPG的方法
2018/11/01 NodeJs
JavaScript 函数用法详解【函数定义、参数、绑定、作用域、闭包等】
2020/05/12 Javascript
vue3.0中使用element的完整步骤
2021/03/04 Vue.js
python实现的一个p2p文件传输实例
2014/06/04 Python
Python内置模块hashlib、hmac与uuid用法分析
2018/02/12 Python
基于tensorflow加载部分层的方法
2018/07/26 Python
细数nn.BCELoss与nn.CrossEntropyLoss的区别
2020/02/29 Python
python 两种方法修改文件的创建时间、修改时间、访问时间
2020/09/26 Python
CSS3 实现时间轴动画
2020/11/25 HTML / CSS
html5 touch事件实现触屏页面上下滑动(二)
2016/03/10 HTML / CSS
意大利顶级奢侈品电商:LUISAVIAROMA(支持中文)
2020/05/26 全球购物
保安部任务及岗位职责
2014/02/25 职场文书
大学学雷锋活动总结
2014/06/26 职场文书
小区的门卫岗位职责
2014/10/01 职场文书
商业门面租房协议书
2014/11/25 职场文书
安全教育片观后感
2015/06/17 职场文书
升学宴学生致辞
2015/07/27 职场文书
Vue全局事件总线你了解吗
2022/02/24 Vue.js
WCG2010 星际争霸决赛 Flash vs Goojila 1 星际经典比赛回顾
2022/04/01 星际争霸
Python+SeaTable实现计算两个日期间的工作日天数
2022/07/07 Python
Win11 Beta 22621.601 和 22622.601今日发布 KB5017384修复内容汇总
2022/09/23 数码科技