🔥 一篇学会CSS过度动画transition

📌前言

css实现动画有两种方式:transition过渡动画、 animation自定义动画。

文章只记录编码中需要并常用的 , 晦涩不常用的就不介绍了, 想学习的同学可以自行搜索相关资料。

本篇介绍transition过渡动画,想学自定义动画稍等作者过几日更新。

🍉transition-duration 动画过度时间

我们编码时常会使用:hover去定义鼠标移入后改变元素的样式,但是在不定义动画时,样式的改变往往是一瞬间的事情。

所以使用transition-duration就变得至关重要,这也是编码最常用的的动画元素。

默认值为0s

可以设置 [number]s以及[number]ms

示例

设置了过渡时间为0.8s

html 复制代码
<div class="divClass"></div>
css 复制代码
.divClass{
  width: 300px;
  height: 300px;
  background: #b5f18e;
  /* 过度时间 */
  transition-duration:0.8s;
}
.divClass:hover{
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: #b5dafc;
}

🍈transition-timing-function动画执行方式

描述
linear 动画从头到尾的速度是相同的。
ease(缓解) 默认值:动画以低速开始,然后加快,在结束前变慢。
ease-in 动画以低速开始。
ease-out 动画以低速结束。
ease-in-out 动画以低速开始和结束。
cubic-bezier(n ,n ,n ,n) 贝塞尔曲线(自定义数值),可到相关网站可视化设置。

因为我为了照顾初学者演示介绍 , 所以编码的变化不多,效果不明显,编码变化效果多的时候会非常明显。

示例

设置了以低速结束

html 复制代码
<div class="divClass"></div>
css 复制代码
.divClass{
  width: 300px;
  height: 300px;
  background: #b5f18e;
  /* 过度时间 */
  transition-duration:2s;
  /* 过度方式 */
  animation-timing-function:ease-out;
}
.divClass:hover{
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: #b5dafc;
}

注意:贝塞尔曲线基本上不会使用 , 不过在特定情况下是需要的 , 可以稍微了解一下

🍇transition-delay动画延迟时间

默认值为0s

可以设置 [number]s以及[number]ms

示例

设置了延迟时间100ms

html 复制代码
<div class="divClass"></div>
css 复制代码
.divClass{
  width: 300px;
  height: 300px;
  background: #b5f18e;
  /* 过度时间 */
  transition-duration:0.8s;
  /* 过度方式 */
  animation-timing-function: ease-in-out;
  /* 过度延迟 */
  transition-delay:1000ms;
}
.divClass:hover{
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: #b5dafc;
}

🍓transition简写

以上三个属性不一定要分开写 , 下面是简写

定义顺序分别为:

  • transition-duration
  • transition-timing-function
  • transition-delay
css 复制代码
transition: 0.8s ease-in-out 1000ms;

📚总结

答应我 , 一定要学会!!!

相关推荐
万少8 小时前
HarmonyOS 开发必会 5 种 Builder 详解
前端·harmonyos
橙序员小站10 小时前
Agent Skill 是什么?一文讲透 Agent Skill 的设计与实现
前端·后端
炫饭第一名13 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
王晓枫13 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊13 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter13 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折13 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_14 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
不会敲代码114 小时前
前端组件化样式隔离实战:React CSS Modules、styled-components 与 Vue scoped 对比
css·vue.js·react.js
Angelial14 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js