文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

css3实现动画的方式有哪些

2024-04-02 19:55

关注

这篇文章将为大家详细讲解有关css3实现动画的方式有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

  css实现动画主要有3种方式,第一种是:transition实现渐变动画,第二种是:transform转变动画,第三种是:animation实现自定义动画。

  transition渐变动画

  我们先看一下transition的属性:

  property:填写需要变化的css属性如:width,line-height,font-size,color等,所有作用与dom样式的属性;

  duration:完成过渡效果需要的时间单位(s或者ms)

  timing-function:完成效果的速度曲线(linear,ease,ease-in,ease-out等等)

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

  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;

  

  

  &:hover {

  width: 200px;

  height: 200px;

  background-color: #5daf34;

  border-width: 10px;

  border-color: #3a8ee6;

  }

  }

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

  transform转变动画

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

  none:定义不进行任何转换,一般用于注册掉该转换。

  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)。

  <h6>transition配合transform一起使用</h6>

  <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);

  }

  }

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

  animation自定义动画

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

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

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

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

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

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

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

  <h6 class="title">animate自定义动画</h6>

  <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实现动画的方式有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯